diff --git a/civicrm.php b/civicrm.php index 51c3709b4f6d1f48bff6217cd52c23f5f3871969..0fc732d65c9f870fdad234e362fbc9a1baf44bf1 100644 --- a/civicrm.php +++ b/civicrm.php @@ -2,7 +2,7 @@ /** * Plugin Name: CiviCRM * Description: CiviCRM - Growing and Sustaining Relationships - * Version: 5.61.1 + * Version: 5.61.2 * Requires at least: 4.9 * Requires PHP: 7.3 * Author: CiviCRM LLC @@ -36,7 +36,7 @@ if (!defined('ABSPATH')) { } // Set version here: changing it forces Javascript and CSS to reload. -define('CIVICRM_PLUGIN_VERSION', '5.61.1'); +define('CIVICRM_PLUGIN_VERSION', '5.61.2'); // Store reference to this file. if (!defined('CIVICRM_PLUGIN_FILE')) { diff --git a/civicrm/CRM/Contribute/Form/Contribution/Main.php b/civicrm/CRM/Contribute/Form/Contribution/Main.php index 9819e8276c08a261535ceaaf09498406a88a83a1..b91317f3d21d7eeb1a5f8287e5a79bcbe2738da1 100644 --- a/civicrm/CRM/Contribute/Form/Contribution/Main.php +++ b/civicrm/CRM/Contribute/Form/Contribution/Main.php @@ -373,7 +373,7 @@ class CRM_Contribute_Form_Contribution_Main extends CRM_Contribute_Form_Contribu // build price set form. $this->set('priceSetId', $this->_priceSetId); if (empty($this->_ccid)) { - CRM_Price_BAO_PriceSet::buildPriceSet($this); + CRM_Price_BAO_PriceSet::buildPriceSet($this, $this->getMainEntityType()); } if ($this->_values['is_monetary'] && $this->_values['is_recur'] && empty($this->_values['pledge_id']) @@ -512,6 +512,7 @@ class CRM_Contribute_Form_Contribution_Main extends CRM_Contribute_Form_Contribu $this->_currentMemberships = []; $membershipTypeIds = $membershipTypes = $radio = $radioOptAttrs = []; + // This is always true if this line is reachable - remove along with the upcoming if. $membershipPriceset = (!empty($this->_priceSetId) && $this->isMembershipPriceSet()); $allowAutoRenewMembership = $autoRenewOption = FALSE; @@ -635,28 +636,6 @@ class CRM_Contribute_Form_Contribution_Main extends CRM_Contribute_Form_Contribu $autoRenewOption = CRM_Price_BAO_PriceSet::checkAutoRenewForPriceSet($this->_priceSetId); $this->assign('autoRenewOption', $autoRenewOption); - if (!$membershipPriceset) { - if (!$this->_membershipBlock['is_required']) { - $this->assign('showRadioNoThanks', TRUE); - $radio['no_thanks'] = NULL; - $this->addRadio('selectMembership', NULL, $radio, [], NULL, FALSE, $radioOptAttrs); - } - elseif ($this->_membershipBlock['is_required'] && count($radio) == 1) { - $temp = array_keys($radio); - $this->add('hidden', 'selectMembership', $temp[0], ['id' => 'selectMembership']); - $this->assign('singleMembership', TRUE); - $this->assign('showRadio', FALSE); - } - else { - foreach ($radioOptAttrs as $opt => $attrs) { - $attrs['class'] = ' required'; - } - $this->addRadio('selectMembership', NULL, $radio, [], NULL, FALSE, $radioOptAttrs); - } - - $this->addRule('selectMembership', ts('Please select one of the memberships.'), 'required'); - } - if ((!$this->_values['is_pay_later'] || is_array($this->_paymentProcessors)) && ($allowAutoRenewMembership || $autoRenewOption)) { if ($autoRenewOption == 2) { $this->addElement('hidden', 'auto_renew', ts('Please renew my membership automatically.')); @@ -784,6 +763,8 @@ class CRM_Contribute_Form_Contribution_Main extends CRM_Contribute_Form_Contribu $self->_useForMember ) ) { + + // appears to be unreachable - selectMembership never set... $isTest = $self->_action & CRM_Core_Action::PREVIEW; $lifeMember = CRM_Member_BAO_Membership::getAllContactMembership($self->_membershipContactID, $isTest, TRUE); diff --git a/civicrm/CRM/Contribute/Form/ContributionBase.php b/civicrm/CRM/Contribute/Form/ContributionBase.php index 8ea9c95123aa736cc032e203cfaeba0a4f62815a..1d41e1ae54cf9a67d98dc5ad075351558a109da7 100644 --- a/civicrm/CRM/Contribute/Form/ContributionBase.php +++ b/civicrm/CRM/Contribute/Form/ContributionBase.php @@ -446,6 +446,7 @@ class CRM_Contribute_Form_ContributionBase extends CRM_Core_Form { $this->set('values', $this->_values); $this->set('fields', $this->_fields); } + $this->assign('isShowMembershipQuickConfigBlock', $this->isShowMembershipQuickConfigBlock()); $this->set('membershipBlock', $this->getMembershipBlock()); // Handle PCP @@ -1304,9 +1305,8 @@ class CRM_Contribute_Form_ContributionBase extends CRM_Core_Form { */ protected function isMembershipPriceSet(): bool { if ($this->_useForMember === NULL) { - if (CRM_Core_Component::isEnabled('CiviMember') && - (!$this->isQuickConfig() || !empty($this->_ccid)) && - (int) CRM_Core_Component::getComponentID('CiviMember') === (int) $this->order->getPriceSetMetadata()['extends']) { + if ($this->getMainEntityType() === 'membership' && + !$this->isQuickConfig()) { $this->_useForMember = 1; } else { @@ -1317,6 +1317,23 @@ class CRM_Contribute_Form_ContributionBase extends CRM_Core_Form { return (bool) $this->_useForMember; } + public function getMainEntityType() { + if (CRM_Core_Component::isEnabled('CiviMember') && (int) CRM_Core_Component::getComponentID('CiviMember') === (int) $this->order->getPriceSetMetadata()['extends']) { + return 'membership'; + } + return 'contribution'; + } + + /** + * Should the membership block be displayed. + * + * This should be shown when the price set is quick config and is a membership price set. + * @return bool + */ + protected function isShowMembershipQuickConfigBlock(): bool { + return CRM_Core_Component::isEnabled('CiviMember') && $this->getMembershipBlock() && $this->isQuickConfig(); + } + /** * Is the contribution page configured for 2 payments, one being membership & one not. * diff --git a/civicrm/CRM/Price/BAO/PriceSet.php b/civicrm/CRM/Price/BAO/PriceSet.php index a5840caee43215d660565cf13d18294a4fa98714..f1097f33043a9577dcfacd4a86331175caf4316a 100644 --- a/civicrm/CRM/Price/BAO/PriceSet.php +++ b/civicrm/CRM/Price/BAO/PriceSet.php @@ -811,10 +811,11 @@ WHERE id = %1"; * Build the price set form. * * @param CRM_Core_Form $form + * @param string|null $component * * @return void */ - public static function buildPriceSet(&$form) { + public static function buildPriceSet(&$form, $component = NULL) { $priceSetId = $form->get('priceSetId'); if (!$priceSetId) { return; @@ -867,23 +868,19 @@ WHERE id = %1"; $form->_priceSet['id'] = $form->_priceSet['id'] ?? $priceSetId; $form->assign('priceSet', $form->_priceSet); - $component = 'contribution'; if ($className == 'CRM_Member_Form_Membership') { $component = 'membership'; } if ($className == 'CRM_Contribute_Form_Contribution_Main') { $feeBlock = &$form->_values['fee']; - if (!empty($form->_useForMember)) { - $component = 'membership'; - } } else { $feeBlock = &$form->_priceSet['fields']; } // Call the buildAmount hook. - CRM_Utils_Hook::buildAmount($component, $form, $feeBlock); + CRM_Utils_Hook::buildAmount($component ?? 'contribution', $form, $feeBlock); self::addPriceFieldsToForm($form, $feeBlock, $validFieldsOnly, $className, $validPriceFieldIds); } diff --git a/civicrm/civicrm-version.php b/civicrm/civicrm-version.php index a78c77b0c699796fb34cff34220446ebe3bd688d..30e6654ffd51ff9038ee25003d20c7bec60803bc 100644 --- a/civicrm/civicrm-version.php +++ b/civicrm/civicrm-version.php @@ -1,7 +1,7 @@ <?php /** @deprecated */ function civicrmVersion( ) { - return array( 'version' => '5.61.1', + return array( 'version' => '5.61.2', 'cms' => 'Wordpress', 'revision' => '' ); } diff --git a/civicrm/ext/afform/admin/info.xml b/civicrm/ext/afform/admin/info.xml index 9ae2819be2303aa270022dc62f8bd9f287cc1a01..61e5d5937e22388f83e646a18787012b0ddf6ad4 100644 --- a/civicrm/ext/afform/admin/info.xml +++ b/civicrm/ext/afform/admin/info.xml @@ -13,7 +13,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2020-01-09</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <develStage>beta</develStage> <compatibility> <ver>5.61</ver> diff --git a/civicrm/ext/afform/core/info.xml b/civicrm/ext/afform/core/info.xml index 642be7a92d35eb47a361e087830c9046b067676b..f463209ec9c1ce757bc3d1a9068def33342961e9 100644 --- a/civicrm/ext/afform/core/info.xml +++ b/civicrm/ext/afform/core/info.xml @@ -13,7 +13,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2020-01-09</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <develStage>beta</develStage> <compatibility> <ver>5.61</ver> diff --git a/civicrm/ext/afform/html/info.xml b/civicrm/ext/afform/html/info.xml index 61500df524a9747ab0cfd8573be862670d341812..6e7eca950bd8512450c4bbbe5ea4aa26ee5e68bd 100644 --- a/civicrm/ext/afform/html/info.xml +++ b/civicrm/ext/afform/html/info.xml @@ -13,7 +13,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2020-01-09</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <develStage>alpha</develStage> <compatibility> <ver>5.61</ver> diff --git a/civicrm/ext/afform/mock/info.xml b/civicrm/ext/afform/mock/info.xml index f1c9782a1e91273de9079704299eaf1326ab0ab7..23ef406bfc1b62691562a14fed06bd5eab933007 100644 --- a/civicrm/ext/afform/mock/info.xml +++ b/civicrm/ext/afform/mock/info.xml @@ -12,7 +12,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2020-01-09</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <tags> <tag>mgmt:hidden</tag> </tags> diff --git a/civicrm/ext/authx/info.xml b/civicrm/ext/authx/info.xml index 2049b4909100fff55dcfc41b59d4eb49ce81ce24..091d383e86f57dd7f9abd2e351f4fdf0bc163a98 100644 --- a/civicrm/ext/authx/info.xml +++ b/civicrm/ext/authx/info.xml @@ -15,7 +15,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2021-02-11</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <develStage>stable</develStage> <compatibility> <ver>5.61</ver> diff --git a/civicrm/ext/civicrm_admin_ui/info.xml b/civicrm/ext/civicrm_admin_ui/info.xml index d3b77c5eb04377fb38f773f0816482284f684c33..dd7c953c5cef361603b1980d4a3c240b1cb6358b 100644 --- a/civicrm/ext/civicrm_admin_ui/info.xml +++ b/civicrm/ext/civicrm_admin_ui/info.xml @@ -15,7 +15,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2022-01-02</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <develStage>alpha</develStage> <compatibility> <ver>5.61</ver> diff --git a/civicrm/ext/civigrant/info.xml b/civicrm/ext/civigrant/info.xml index 15076dbb17d6ccba79bf1013e7529b71ed189f4c..a4ccdb18750c2e42d5460b09de15b74e255cda2c 100644 --- a/civicrm/ext/civigrant/info.xml +++ b/civicrm/ext/civigrant/info.xml @@ -13,7 +13,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2021-11-11</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <develStage>stable</develStage> <compatibility> <ver>5.61</ver> diff --git a/civicrm/ext/civiimport/info.xml b/civicrm/ext/civiimport/info.xml index ba688a0ada555334ba21d5e6b270dfe70305db3b..6ec0c2e79aef4a05627b5709b4fb32b5418bb6a4 100644 --- a/civicrm/ext/civiimport/info.xml +++ b/civicrm/ext/civiimport/info.xml @@ -15,7 +15,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2022-08-11</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <develStage>alpha</develStage> <compatibility> <ver>5.61</ver> diff --git a/civicrm/ext/ckeditor4/info.xml b/civicrm/ext/ckeditor4/info.xml index ef39808484f209f48964f647adcfb00e2146b085..632f2961c9502df72ab5cd7d6d90422535520d89 100644 --- a/civicrm/ext/ckeditor4/info.xml +++ b/civicrm/ext/ckeditor4/info.xml @@ -15,7 +15,7 @@ <url desc="Licensing">https://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2021-05-23</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <develStage>stable</develStage> <compatibility> <ver>5.61</ver> diff --git a/civicrm/ext/contributioncancelactions/info.xml b/civicrm/ext/contributioncancelactions/info.xml index e71c1d7e563e6a772eaec8a4f560422f86b8b218..132737d9e3eb20a2d7da204f9afbb7e12ba83b86 100644 --- a/civicrm/ext/contributioncancelactions/info.xml +++ b/civicrm/ext/contributioncancelactions/info.xml @@ -15,7 +15,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2020-10-12</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <develStage>stable</develStage> <compatibility> <ver>5.61</ver> diff --git a/civicrm/ext/elavon/info.xml b/civicrm/ext/elavon/info.xml index 53c9fe47dac337b174cc90f8442e7894c85f1804..672304495ed4ad9e0bdab14e2cebf1e0219fb7ec 100644 --- a/civicrm/ext/elavon/info.xml +++ b/civicrm/ext/elavon/info.xml @@ -15,7 +15,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2022-08-05</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <develStage>stable</develStage> <compatibility> <ver>5.61</ver> diff --git a/civicrm/ext/eventcart/info.xml b/civicrm/ext/eventcart/info.xml index 55e6aafa1df506d115d5318602913002e3ba5e07..180c8427c783a6b83cad13646ec6aed68ce8fa84 100644 --- a/civicrm/ext/eventcart/info.xml +++ b/civicrm/ext/eventcart/info.xml @@ -13,7 +13,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2020-08-03</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <tags> <tag>mgmt:hidden</tag> </tags> diff --git a/civicrm/ext/ewaysingle/info.xml b/civicrm/ext/ewaysingle/info.xml index bea226e36d962928f5caaad28b6cb5b6307e47f7..a6c127b65221a4aeef7226fe8e5b25f6389d4018 100644 --- a/civicrm/ext/ewaysingle/info.xml +++ b/civicrm/ext/ewaysingle/info.xml @@ -15,7 +15,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2020-10-07</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <tags> <tag>mgmt:hidden</tag> </tags> diff --git a/civicrm/ext/financialacls/info.xml b/civicrm/ext/financialacls/info.xml index 3c1f9bd3b50a6d04a50007bbd694d41a3d1c5783..e06fe1e018bbe7e231413df7c05f0c2e77845600 100644 --- a/civicrm/ext/financialacls/info.xml +++ b/civicrm/ext/financialacls/info.xml @@ -15,7 +15,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2020-08-27</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <develStage>stable</develStage> <compatibility> <ver>5.61</ver> diff --git a/civicrm/ext/flexmailer/info.xml b/civicrm/ext/flexmailer/info.xml index 45c348cffc25dc49c9561e0b57769cfd42b7acc6..8d51305e414b6426bf131d569e22d16b79d33a66 100644 --- a/civicrm/ext/flexmailer/info.xml +++ b/civicrm/ext/flexmailer/info.xml @@ -15,7 +15,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2020-08-05</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <develStage>stable</develStage> <comments> FlexMailer is an email delivery engine which replaces the internal guts diff --git a/civicrm/ext/greenwich/info.xml b/civicrm/ext/greenwich/info.xml index 70b3b921b3743edc5d490d792ed8722605103ce3..5fe955dcb304ca0e0e5209f47636b9818111c8b3 100644 --- a/civicrm/ext/greenwich/info.xml +++ b/civicrm/ext/greenwich/info.xml @@ -15,7 +15,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2020-07-21</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <tags> <tag>mgmt:hidden</tag> </tags> diff --git a/civicrm/ext/legacycustomsearches/info.xml b/civicrm/ext/legacycustomsearches/info.xml index 0fd729e8540f188426a8d35624be3bf7de52489f..33888e32c59b600cb8c5569d28b52ff546efee77 100644 --- a/civicrm/ext/legacycustomsearches/info.xml +++ b/civicrm/ext/legacycustomsearches/info.xml @@ -15,7 +15,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2021-07-25</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <develStage>stable</develStage> <tags> <tag>mgmt:hidden</tag> diff --git a/civicrm/ext/message_admin/info.xml b/civicrm/ext/message_admin/info.xml index 39bb0f660de0fa468b72892dbae4facee9338b39..36c2d4b0dc31eb38621f2766fc45c496deaad74f 100644 --- a/civicrm/ext/message_admin/info.xml +++ b/civicrm/ext/message_admin/info.xml @@ -15,7 +15,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2021-06-12</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <develStage>alpha</develStage> <compatibility> <ver>5.61</ver> diff --git a/civicrm/ext/oauth-client/info.xml b/civicrm/ext/oauth-client/info.xml index db888a9e7a94af4f032ca92e07167e1f07b56a7b..6cb5f5bffbb52778e9f1c24232e57f80b49efc2f 100644 --- a/civicrm/ext/oauth-client/info.xml +++ b/civicrm/ext/oauth-client/info.xml @@ -15,7 +15,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2020-10-23</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <develStage>stable</develStage> <compatibility> <ver>5.61</ver> diff --git a/civicrm/ext/payflowpro/info.xml b/civicrm/ext/payflowpro/info.xml index 6ada15c9b0f3130bdc634b71eb896960b6d32624..a4cd20258eff112fb650e896cc65d8e6c78e6f62 100644 --- a/civicrm/ext/payflowpro/info.xml +++ b/civicrm/ext/payflowpro/info.xml @@ -15,7 +15,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2021-04-13</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <develStage>stable</develStage> <compatibility> <ver>5.61</ver> diff --git a/civicrm/ext/recaptcha/info.xml b/civicrm/ext/recaptcha/info.xml index 890ca4a2315025d4c98951c953ba237b18b761f3..e0389fb017dfec4b0b371553e8b54a155d308aef 100644 --- a/civicrm/ext/recaptcha/info.xml +++ b/civicrm/ext/recaptcha/info.xml @@ -13,7 +13,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2021-04-03</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <tags> <tag>mgmt:hidden</tag> </tags> diff --git a/civicrm/ext/search_kit/info.xml b/civicrm/ext/search_kit/info.xml index 4094ee3474a46925f1e3f8bbc035348e80b5050d..dcd87dc96131634c7bf5c75cbb7fbb56a78c5e8d 100644 --- a/civicrm/ext/search_kit/info.xml +++ b/civicrm/ext/search_kit/info.xml @@ -15,7 +15,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2021-01-06</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <develStage>stable</develStage> <tags> <tag>mgmt:required</tag> diff --git a/civicrm/ext/sequentialcreditnotes/info.xml b/civicrm/ext/sequentialcreditnotes/info.xml index a4c729a2366b79e8ee8617fb6a768d6a55a7f01f..55ab4ca7f67fe954a2e42c53cec7397af61a3386 100644 --- a/civicrm/ext/sequentialcreditnotes/info.xml +++ b/civicrm/ext/sequentialcreditnotes/info.xml @@ -15,7 +15,7 @@ <url desc="Licensing">http://www.gnu.org/licenses/agpl-3.0.html</url> </urls> <releaseDate>2020-01-28</releaseDate> - <version>5.61.1</version> + <version>5.61.2</version> <tags> <tag>mgmt:hidden</tag> </tags> diff --git a/civicrm/release-notes.md b/civicrm/release-notes.md index 7a91c862a8845f51d3f4793ca61a8a6149748a29..c3c4d2e8a73345b6f30ec34b9a3603f10c72c6ec 100644 --- a/civicrm/release-notes.md +++ b/civicrm/release-notes.md @@ -15,6 +15,15 @@ Other resources for identifying changes are: * https://github.com/civicrm/civicrm-joomla * https://github.com/civicrm/civicrm-wordpress +## CiviCRM 5.61.2 + +Released May 8, 2023 + +- **[Synopsis](release-notes/5.61.2.md#synopsis)** +- **[Bugs resolved](release-notes/5.61.2.md#bugs)** +- **[Credits](release-notes/5.61.2.md#credits)** +- **[Feedback](release-notes/5.61.2.md#feedback)** + ## CiviCRM 5.61.1 Released May 5, 2023 diff --git a/civicrm/release-notes/5.61.2.md b/civicrm/release-notes/5.61.2.md new file mode 100644 index 0000000000000000000000000000000000000000..09ef0612d780333db6f9424e3ad177449ac85ddb --- /dev/null +++ b/civicrm/release-notes/5.61.2.md @@ -0,0 +1,38 @@ +# CiviCRM 5.61.2 + +Released May 8, 2023 + +- **[Synopsis](#synopsis)** +- **[Bugs resolved](#bugs)** +- **[Credits](#credits)** +- **[Feedback](#feedback)** + +## <a name="synopsis"></a>Synopsis + +| *Does this version...?* | | +| --------------------------------------------------------------- | -------- | +| Change the database schema? | no | +| Alter the API? | no | +| Require attention to configuration options? | no | +| Fix problems installing or upgrading to a previous version? | no | +| Introduce features? | no | +| **Fix bugs?** | **yes** | +| Fix security vulnerabilities? | no | + +## <a name="bugs"></a>Bugs resolved + +* **_CiviMember_: Cannot submit certain membership forms (non-"quick config" forms) ([dev/core#4282](https://lab.civicrm.org/dev/core/-/issues/4282): [#26170](https://github.com/civicrm/civicrm-core/pull/26170))** +* **_Drupal_: Extraneous warnings logged for non-CiviCRM pages (Drupal 8/9/10) ([drupal#85](https://github.com/civicrm/civicrm-drupal-8/pull/85))** + +## <a name="credits"></a>Credits + +This release was developed by the following authors and reviewers: + +Wikimedia Foundation - Eileen McNaughton; Semper IT - Karin Gerritsen; HeneryH; Fuzion - +Jitendra Purohit; Dave D; composerjk; CiviCRM - Tim Otten + +## <a name="feedback"></a>Feedback + +These release notes are edited by Tim Otten and Andie Hunt. If you'd like to +provide feedback on them, please login to https://chat.civicrm.org/civicrm and +contact `@agh1`. diff --git a/civicrm/sql/civicrm_data.mysql b/civicrm/sql/civicrm_data.mysql index a9fa10da987abdd546faa04855290b722b8f5ca6..ed49f429fd0e1dc8ee739791b8da07038dcab710 100644 --- a/civicrm/sql/civicrm_data.mysql +++ b/civicrm/sql/civicrm_data.mysql @@ -23678,4 +23678,4 @@ INSERT INTO `civicrm_report_instance` ( `domain_id`, `title`, `report_id`, `description`, `permission`, `form_values`) VALUES ( @domainID, 'Survey Details', 'survey/detail', 'Detailed report for canvassing, phone-banking, walk lists or other surveys.', 'access CiviReport', 'a:39:{s:6:"fields";a:2:{s:9:"sort_name";s:1:"1";s:6:"result";s:1:"1";}s:22:"assignee_contact_id_op";s:2:"eq";s:25:"assignee_contact_id_value";s:0:"";s:12:"sort_name_op";s:3:"has";s:15:"sort_name_value";s:0:"";s:17:"street_number_min";s:0:"";s:17:"street_number_max";s:0:"";s:16:"street_number_op";s:3:"lte";s:19:"street_number_value";s:0:"";s:14:"street_name_op";s:3:"has";s:17:"street_name_value";s:0:"";s:15:"postal_code_min";s:0:"";s:15:"postal_code_max";s:0:"";s:14:"postal_code_op";s:3:"lte";s:17:"postal_code_value";s:0:"";s:7:"city_op";s:3:"has";s:10:"city_value";s:0:"";s:20:"state_province_id_op";s:2:"in";s:23:"state_province_id_value";a:0:{}s:13:"country_id_op";s:2:"in";s:16:"country_id_value";a:0:{}s:12:"survey_id_op";s:2:"in";s:15:"survey_id_value";a:0:{}s:12:"status_id_op";s:2:"eq";s:15:"status_id_value";s:1:"1";s:11:"custom_1_op";s:2:"in";s:14:"custom_1_value";a:0:{}s:11:"custom_2_op";s:2:"in";s:14:"custom_2_value";a:0:{}s:17:"custom_3_relative";s:1:"0";s:13:"custom_3_from";s:0:"";s:11:"custom_3_to";s:0:"";s:11:"description";s:75:"Detailed report for canvassing, phone-banking, walk lists or other surveys.";s:13:"email_subject";s:0:"";s:8:"email_to";s:0:"";s:8:"email_cc";s:0:"";s:10:"permission";s:17:"access CiviReport";s:6:"groups";s:0:"";s:9:"domain_id";i:1;}'); -UPDATE civicrm_domain SET version = '5.61.1'; +UPDATE civicrm_domain SET version = '5.61.2'; diff --git a/civicrm/sql/civicrm_generated.mysql b/civicrm/sql/civicrm_generated.mysql index f15128d1f4476c543f4c82110920da983ee6ef7c..7d6bafcf96ea87ff0c0c2c2c6a3b801f72d08ee2 100644 --- a/civicrm/sql/civicrm_generated.mysql +++ b/civicrm/sql/civicrm_generated.mysql @@ -3059,7 +3059,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_domain` WRITE; /*!40000 ALTER TABLE `civicrm_domain` DISABLE KEYS */; INSERT INTO `civicrm_domain` (`id`, `name`, `description`, `version`, `contact_id`, `locales`, `locale_custom_strings`) VALUES - (1,'Default Domain Name',NULL,'5.61.1',1,NULL,'a:1:{s:5:\"en_US\";a:0:{}}'); + (1,'Default Domain Name',NULL,'5.61.2',1,NULL,'a:1:{s:5:\"en_US\";a:0:{}}'); /*!40000 ALTER TABLE `civicrm_domain` ENABLE KEYS */; UNLOCK TABLES; diff --git a/civicrm/templates/CRM/Contribute/Form/Contribution/Main.tpl b/civicrm/templates/CRM/Contribute/Form/Contribution/Main.tpl index a7ee32e09e5eb1db14e451b97dbc01d5f512308e..3a0c541a7e33f3b430d96b9177a65bfd02d0a3d8 100644 --- a/civicrm/templates/CRM/Contribute/Form/Contribution/Main.tpl +++ b/civicrm/templates/CRM/Contribute/Form/Contribution/Main.tpl @@ -76,7 +76,7 @@ <div class="help">{ts}You have a current Lifetime Membership which does not need to be renewed.{/ts}</div> {/if} - {if !empty($useForMember) && !$ccid} + {if $isShowMembershipQuickConfigBlock && !$ccid} <div class="crm-public-form-item crm-section"> {include file="CRM/Contribute/Form/Contribution/MembershipBlock.tpl" context="makeContribution"} </div> diff --git a/civicrm/templates/CRM/Contribute/Form/Contribution/MembershipBlock.tpl b/civicrm/templates/CRM/Contribute/Form/Contribution/MembershipBlock.tpl index 796834c64bd9ccf9259d646b9018020cb044ad7e..fd70bbe2495630e2227a7fa721a8054c833b0623 100644 --- a/civicrm/templates/CRM/Contribute/Form/Contribution/MembershipBlock.tpl +++ b/civicrm/templates/CRM/Contribute/Form/Contribution/MembershipBlock.tpl @@ -7,7 +7,7 @@ | and copyright information, see https://civicrm.org/licensing | +--------------------------------------------------------------------+ *} -{if !empty($useForMember) AND !$is_quick_config} +{if $isShowMembershipQuickConfigBlock} <div id="membership" class="crm-group membership-group"> {if $context EQ "makeContribution"} <div id="priceset"> @@ -158,6 +158,7 @@ {foreach from=$membershipTypes item=row} <tr {if $context EQ "makeContribution"}class="odd-row" {/if}valign="top"> {if $showRadio } + {* unreachable - show radio is never true *} {assign var="pid" value=$row.id} <td style="width: 1em;">{$form.selectMembership.$pid.html}</td> {else} @@ -203,7 +204,7 @@ </td> </tr> {/if} - {if $showRadio} + {if $showRadio}{* unreachable *} {if $showRadioNoThanks } {* Provide no-thanks option when Membership signup is not required - per membership block configuration. *} <tr class="odd-row"> <td>{$form.selectMembership.no_thanks.html}</td> diff --git a/civicrm/vendor/autoload.php b/civicrm/vendor/autoload.php index c0310fbb65fa8346fa38b1e59db2ada7d845c471..6156998a3bdbcd2f183bb12acfd61c408905da4f 100644 --- a/civicrm/vendor/autoload.php +++ b/civicrm/vendor/autoload.php @@ -4,4 +4,4 @@ require_once __DIR__ . '/composer/autoload_real.php'; -return ComposerAutoloaderInitb2e964434007560ae238a86ef426dac5::getLoader(); +return ComposerAutoloaderInit44b9c719a70155244dfb6c35eb6d8e26::getLoader(); diff --git a/civicrm/vendor/composer/autoload_real.php b/civicrm/vendor/composer/autoload_real.php index c1dc5d647a8192bff035cbbdd4ad11b3deffb312..6387f47cca602b00b3fe232c6d6517c911d30550 100644 --- a/civicrm/vendor/composer/autoload_real.php +++ b/civicrm/vendor/composer/autoload_real.php @@ -2,7 +2,7 @@ // autoload_real.php @generated by Composer -class ComposerAutoloaderInitb2e964434007560ae238a86ef426dac5 +class ComposerAutoloaderInit44b9c719a70155244dfb6c35eb6d8e26 { private static $loader; @@ -24,9 +24,9 @@ class ComposerAutoloaderInitb2e964434007560ae238a86ef426dac5 require __DIR__ . '/platform_check.php'; - spl_autoload_register(array('ComposerAutoloaderInitb2e964434007560ae238a86ef426dac5', 'loadClassLoader'), true, true); + spl_autoload_register(array('ComposerAutoloaderInit44b9c719a70155244dfb6c35eb6d8e26', 'loadClassLoader'), true, true); self::$loader = $loader = new \Composer\Autoload\ClassLoader(\dirname(\dirname(__FILE__))); - spl_autoload_unregister(array('ComposerAutoloaderInitb2e964434007560ae238a86ef426dac5', 'loadClassLoader')); + spl_autoload_unregister(array('ComposerAutoloaderInit44b9c719a70155244dfb6c35eb6d8e26', 'loadClassLoader')); $includePaths = require __DIR__ . '/include_paths.php'; $includePaths[] = get_include_path(); @@ -36,7 +36,7 @@ class ComposerAutoloaderInitb2e964434007560ae238a86ef426dac5 if ($useStaticLoader) { require __DIR__ . '/autoload_static.php'; - call_user_func(\Composer\Autoload\ComposerStaticInitb2e964434007560ae238a86ef426dac5::getInitializer($loader)); + call_user_func(\Composer\Autoload\ComposerStaticInit44b9c719a70155244dfb6c35eb6d8e26::getInitializer($loader)); } else { $map = require __DIR__ . '/autoload_namespaces.php'; foreach ($map as $namespace => $path) { @@ -57,12 +57,12 @@ class ComposerAutoloaderInitb2e964434007560ae238a86ef426dac5 $loader->register(true); if ($useStaticLoader) { - $includeFiles = Composer\Autoload\ComposerStaticInitb2e964434007560ae238a86ef426dac5::$files; + $includeFiles = Composer\Autoload\ComposerStaticInit44b9c719a70155244dfb6c35eb6d8e26::$files; } else { $includeFiles = require __DIR__ . '/autoload_files.php'; } foreach ($includeFiles as $fileIdentifier => $file) { - composerRequireb2e964434007560ae238a86ef426dac5($fileIdentifier, $file); + composerRequire44b9c719a70155244dfb6c35eb6d8e26($fileIdentifier, $file); } return $loader; @@ -74,7 +74,7 @@ class ComposerAutoloaderInitb2e964434007560ae238a86ef426dac5 * @param string $file * @return void */ -function composerRequireb2e964434007560ae238a86ef426dac5($fileIdentifier, $file) +function composerRequire44b9c719a70155244dfb6c35eb6d8e26($fileIdentifier, $file) { if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) { $GLOBALS['__composer_autoload_files'][$fileIdentifier] = true; diff --git a/civicrm/vendor/composer/autoload_static.php b/civicrm/vendor/composer/autoload_static.php index 376b53fe6bef2a71b200bc8317366e072a35d156..2b7d690b147dccab6a12d431f428d52187b451ad 100644 --- a/civicrm/vendor/composer/autoload_static.php +++ b/civicrm/vendor/composer/autoload_static.php @@ -4,7 +4,7 @@ namespace Composer\Autoload; -class ComposerStaticInitb2e964434007560ae238a86ef426dac5 +class ComposerStaticInit44b9c719a70155244dfb6c35eb6d8e26 { public static $files = array ( 'a4a119a56e50fbb293281d9a48007e0e' => __DIR__ . '/..' . '/symfony/polyfill-php80/bootstrap.php', @@ -729,11 +729,11 @@ class ComposerStaticInitb2e964434007560ae238a86ef426dac5 public static function getInitializer(ClassLoader $loader) { return \Closure::bind(function () use ($loader) { - $loader->prefixLengthsPsr4 = ComposerStaticInitb2e964434007560ae238a86ef426dac5::$prefixLengthsPsr4; - $loader->prefixDirsPsr4 = ComposerStaticInitb2e964434007560ae238a86ef426dac5::$prefixDirsPsr4; - $loader->prefixesPsr0 = ComposerStaticInitb2e964434007560ae238a86ef426dac5::$prefixesPsr0; - $loader->fallbackDirsPsr0 = ComposerStaticInitb2e964434007560ae238a86ef426dac5::$fallbackDirsPsr0; - $loader->classMap = ComposerStaticInitb2e964434007560ae238a86ef426dac5::$classMap; + $loader->prefixLengthsPsr4 = ComposerStaticInit44b9c719a70155244dfb6c35eb6d8e26::$prefixLengthsPsr4; + $loader->prefixDirsPsr4 = ComposerStaticInit44b9c719a70155244dfb6c35eb6d8e26::$prefixDirsPsr4; + $loader->prefixesPsr0 = ComposerStaticInit44b9c719a70155244dfb6c35eb6d8e26::$prefixesPsr0; + $loader->fallbackDirsPsr0 = ComposerStaticInit44b9c719a70155244dfb6c35eb6d8e26::$fallbackDirsPsr0; + $loader->classMap = ComposerStaticInit44b9c719a70155244dfb6c35eb6d8e26::$classMap; }, null, ClassLoader::class); } diff --git a/civicrm/vendor/composer/installed.php b/civicrm/vendor/composer/installed.php index 2ed1634d240f2699250299d899eef533f540be88..00551ead4f036445ea7ba3a9669daa18a72a1bd2 100644 --- a/civicrm/vendor/composer/installed.php +++ b/civicrm/vendor/composer/installed.php @@ -5,7 +5,7 @@ 'type' => 'library', 'install_path' => __DIR__ . '/../../', 'aliases' => array(), - 'reference' => '8fd20b11d8a67e4c71ce5c6828fc358b00e87c94', + 'reference' => 'f87b1d41eb7420a6434b75f87dbcac32bb103f6b', 'name' => 'civicrm/civicrm-core', 'dev' => true, ), @@ -43,7 +43,7 @@ 'type' => 'library', 'install_path' => __DIR__ . '/../../', 'aliases' => array(), - 'reference' => '8fd20b11d8a67e4c71ce5c6828fc358b00e87c94', + 'reference' => 'f87b1d41eb7420a6434b75f87dbcac32bb103f6b', 'dev_requirement' => false, ), 'civicrm/civicrm-cxn-rpc' => array( diff --git a/civicrm/xml/version.xml b/civicrm/xml/version.xml index 649a4c66f9559131906512593f0c9a35c05cab7e..6a6e403897d90140ef044a13b1b35883564c55c4 100644 --- a/civicrm/xml/version.xml +++ b/civicrm/xml/version.xml @@ -1,4 +1,4 @@ <?xml version="1.0" encoding="iso-8859-1" ?> <version> - <version_no>5.61.1</version_no> + <version_no>5.61.2</version_no> </version>