From 531d3b28bc0693c153c50f9ea9a743448e21dcac Mon Sep 17 00:00:00 2001 From: "Matthew Wire (MJW Consulting)" Date: Mon, 22 Apr 2019 13:22:08 +0100 Subject: [PATCH] Replace hardcoded IDs with pseudoconstants in activity form --- CRM/Activity/Form/Activity.php | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/CRM/Activity/Form/Activity.php b/CRM/Activity/Form/Activity.php index 680188871e0c..a3fef8d7d8f0 100644 --- a/CRM/Activity/Form/Activity.php +++ b/CRM/Activity/Form/Activity.php @@ -602,7 +602,7 @@ public function setDefaultValues() { } // CRM-15472 - 50 is around the practical limit of how many items a select2 entityRef can handle - if ($this->_action == 2 && !empty($defaults['target_contact_id'])) { + if ($this->_action == CRM_Core_Action::UPDATE && !empty($defaults['target_contact_id'])) { $count = count(is_array($defaults['target_contact_id']) ? $defaults['target_contact_id'] : explode(',', $defaults['target_contact_id'])); if ($count > 50) { $this->freeze(['target_contact_id']); @@ -860,14 +860,12 @@ public static function formRule($fields, $files, $self) { $errors['activity_type_id'] = ts('Activity Type is a required field'); } - if (CRM_Utils_Array::value('activity_type_id', $fields) == 3 && - CRM_Utils_Array::value('status_id', $fields) == 1 - ) { + if (CRM_Utils_Array::value('activity_type_id', $fields) == CRM_Core_PseudoConstant::getKey('CRM_Activity_BAO_Activity', 'activity_type_id', 'Email') + && CRM_Utils_Array::value('status_id', $fields) == CRM_Core_PseudoConstant::getKey('CRM_Activity_BAO_Activity', 'status_id', 'Scheduled')) { $errors['status_id'] = ts('You cannot record scheduled email activity.'); } - elseif (CRM_Utils_Array::value('activity_type_id', $fields) == 4 && - CRM_Utils_Array::value('status_id', $fields) == 1 - ) { + elseif (CRM_Utils_Array::value('activity_type_id', $fields) == CRM_Core_PseudoConstant::getKey('CRM_Activity_BAO_Activity', 'activity_type_id', 'SMS') + && CRM_Utils_Array::value('status_id', $fields) == CRM_Core_PseudoConstant::getKey('CRM_Activity_BAO_Activity', 'status_id', 'Scheduled')) { $errors['status_id'] = ts('You cannot record scheduled SMS activity.'); } @@ -896,7 +894,9 @@ public static function formRule($fields, $files, $self) { * * * @param array $params + * @return array|null + * @throws \CiviCRM_API3_Exception */ public function postProcess($params = NULL) { if ($this->_action & CRM_Core_Action::DELETE) {