[REF] Remove deprecated code from CRM_Admin_Form_Preferences
authoreileen <emcnaughton@wikimedia.org>
Tue, 28 Jan 2020 02:44:06 +0000 (15:44 +1300)
committereileen <emcnaughton@wikimedia.org>
Tue, 28 Jan 2020 02:44:08 +0000 (15:44 +1300)
This form was cleaned up back in 2018 but all the stuff to handle ->_varNames was deprecated rather than
removed in case extensions were leveraging it in some way. I'm removing it now although I commented rather
than removed a few lines that I suspect can also go

CRM/Admin/Form/Preferences.php

index f0dc5c9a364f5dd932ab8a072dbd0b36fdec4f39..343df0fdd1b43d93281a2ad5bee78b3a5aa74435 100644 (file)
@@ -26,15 +26,17 @@ class CRM_Admin_Form_Preferences extends CRM_Core_Form {
   protected $_contactID = NULL;
   public $_action = NULL;
 
-  protected $_checkbox = NULL;
-
-  protected $_varNames = [];
-
-  protected $_config = NULL;
-
   protected $_params = NULL;
 
+  /**
+   * Preprocess form.
+   *
+   * @throws \CRM_Core_Exception
+   */
   public function preProcess() {
+    // @todo - it's likely the only 'current' code in this function is the line
+    // $this->addFieldsDefinedInSettingsMetadata(); and this class is no different to CRM_Admin_Form_Setting
+    // in any meaningful way.
     $this->_contactID = CRM_Utils_Request::retrieve('cid', 'Positive',
       $this, FALSE
     );
@@ -44,44 +46,27 @@ class CRM_Admin_Form_Preferences extends CRM_Core_Form {
     $this->_action = CRM_Utils_Request::retrieve('action', 'String',
       $this, FALSE, 'update'
     );
-    if (isset($action)) {
-      $this->assign('action', $action);
-    }
-
-    $session = CRM_Core_Session::singleton();
-
-    $this->_config = new CRM_Core_DAO();
 
     if ($this->_system) {
       if (CRM_Core_Permission::check('administer CiviCRM')) {
         $this->_contactID = NULL;
       }
       else {
-        CRM_Utils_System::fatal('You do not have permission to edit preferences');
+        throw new CRM_Core_Exception('You do not have permission to edit preferences');
       }
-      $this->_config->contact_id = NULL;
     }
     else {
       if (!$this->_contactID) {
-        $this->_contactID = $session->get('userID');
+        $this->_contactID = CRM_Core_Session::getLoggedInContactID();
         if (!$this->_contactID) {
-          CRM_Utils_System::fatal('Could not retrieve contact id');
+          throw new CRM_Core_Exception('Could not retrieve contact id');
         }
         $this->set('cid', $this->_contactID);
       }
-      $this->_config->contact_id = $this->_contactID;
     }
 
     $this->addFieldsDefinedInSettingsMetadata();
-    $settings = Civi::settings();
-    // @todo replace this by defining all in settings.
-    foreach ($this->_varNames as $groupName => $settingNames) {
-      CRM_Core_Error::deprecatedFunctionWarning('deprecated use of preferences form. This will be removed from core soon');
-      foreach ($settingNames as $settingName => $options) {
-        $this->_config->$settingName = $settings->get($settingName);
-      }
-    }
-    $session->pushUserContext(CRM_Utils_System::url('civicrm/admin', 'reset=1'));
+    CRM_Core_Session::singleton()->pushUserContext(CRM_Utils_System::url('civicrm/admin', 'reset=1'));
   }
 
   /**
@@ -89,128 +74,16 @@ class CRM_Admin_Form_Preferences extends CRM_Core_Form {
    */
   public function setDefaultValues() {
     $this->_defaults = [];
-
     $this->setDefaultsForMetadataDefinedFields();
-    foreach ($this->_varNames as $groupName => $settings) {
-      CRM_Core_Error::deprecatedFunctionWarning('deprecated use of preferences form. This will be removed from core soon');
-      foreach ($settings as $settingName => $settingDetails) {
-        $this->_defaults[$settingName] = isset($this->_config->$settingName) ? $this->_config->$settingName : CRM_Utils_Array::value('default', $settingDetails, NULL);
-      }
-    }
-
     return $this->_defaults;
   }
 
-  /**
-   * @todo deprecate in favour of setting using metadata.
-   *
-   * @param $defaults
-   */
-  public function cbsDefaultValues(&$defaults) {
-
-    foreach ($this->_varNames as $groupName => $groupValues) {
-      CRM_Core_Error::deprecatedFunctionWarning('deprecated use of preferences form. This will be removed from core soon');
-      foreach ($groupValues as $settingName => $fieldValue) {
-        if ($fieldValue['html_type'] == 'checkboxes') {
-          if (isset($this->_config->$settingName) &&
-            $this->_config->$settingName
-          ) {
-            $value = explode(CRM_Core_DAO::VALUE_SEPARATOR,
-              substr($this->_config->$settingName, 1, -1)
-            );
-            if (!empty($value)) {
-              $defaults[$settingName] = [];
-              foreach ($value as $n => $v) {
-                $defaults[$settingName][$v] = 1;
-              }
-            }
-          }
-        }
-      }
-    }
-  }
-
   /**
    * Build the form object.
    */
   public function buildQuickForm() {
     parent::buildQuickForm();
 
-    if (!empty($this->_varNames)) {
-      CRM_Core_Error::deprecatedFunctionWarning('deprecated use of preferences form. This will be removed from core soon');
-      foreach ($this->_varNames as $groupName => $groupValues) {
-        $formName = CRM_Utils_String::titleToVar($groupName);
-        $this->assign('formName', $formName);
-        $fields = [];
-        foreach ($groupValues as $fieldName => $fieldValue) {
-          $fields[$fieldName] = $fieldValue;
-
-          switch ($fieldValue['html_type']) {
-            case 'text':
-              $this->addElement('text',
-                $fieldName,
-                $fieldValue['title'],
-                [
-                  'maxlength' => 64,
-                  'size' => 32,
-                ]
-              );
-              break;
-
-            case 'textarea':
-            case 'checkbox':
-              $this->add($fieldValue['html_type'],
-                $fieldName,
-                $fieldValue['title']
-              );
-              break;
-
-            case 'radio':
-              $options = CRM_Core_OptionGroup::values($fieldName, FALSE, FALSE, TRUE);
-              $this->addRadio($fieldName, $fieldValue['title'], $options, NULL, '&nbsp;&nbsp;');
-              break;
-
-            case 'YesNo':
-              $this->addRadio($fieldName, $fieldValue['title'], [0 => 'No', 1 => 'Yes'], NULL, '&nbsp;&nbsp;');
-              break;
-
-            case 'checkboxes':
-              $options = array_flip(CRM_Core_OptionGroup::values($fieldName, FALSE, FALSE, TRUE));
-              $newOptions = [];
-              foreach ($options as $key => $val) {
-                $newOptions[$key] = $val;
-              }
-              $this->addCheckBox($fieldName,
-                $fieldValue['title'],
-                $newOptions,
-                NULL, NULL, NULL, NULL,
-                ['&nbsp;&nbsp;', '&nbsp;&nbsp;', '<br/>']
-              );
-              break;
-
-            case 'select':
-              $this->addElement('select',
-                $fieldName,
-                $fieldValue['title'],
-                $fieldValue['option_values'],
-                CRM_Utils_Array::value('attributes', $fieldValue)
-              );
-              break;
-
-            case 'wysiwyg':
-              $this->add('wysiwyg', $fieldName, $fieldValue['title'], $fieldValue['attributes']);
-              break;
-
-            case 'entity_reference':
-              $this->addEntityRef($fieldName, $fieldValue['title'], CRM_Utils_Array::value('options', $fieldValue, []));
-          }
-        }
-
-        $fields = CRM_Utils_Array::crmArraySortByField($fields, 'weight');
-        $this->assign('fields', $fields);
-      }
-    }
-
     $this->addButtons([
       [
         'type' => 'next',
@@ -232,7 +105,6 @@ class CRM_Admin_Form_Preferences extends CRM_Core_Form {
    * Process the form submission.
    */
   public function postProcess() {
-    $config = CRM_Core_Config::singleton();
     if ($this->_action == CRM_Core_Action::VIEW) {
       return;
     }
@@ -254,52 +126,6 @@ class CRM_Admin_Form_Preferences extends CRM_Core_Form {
       CRM_Core_Session::setStatus($e->getMessage(), ts('Save Failed'), 'error');
     }
 
-    foreach ($this->_varNames as $groupName => $groupValues) {
-      foreach ($groupValues as $settingName => $fieldValue) {
-        switch ($fieldValue['html_type']) {
-          case 'checkboxes':
-            if (!empty($this->_params[$settingName]) &&
-              is_array($this->_params[$settingName])
-            ) {
-              $this->_config->$settingName = CRM_Core_DAO::VALUE_SEPARATOR . implode(CRM_Core_DAO::VALUE_SEPARATOR,
-                  array_keys($this->_params[$settingName])
-                ) . CRM_Core_DAO::VALUE_SEPARATOR;
-            }
-            else {
-              $this->_config->$settingName = NULL;
-            }
-            break;
-
-          case 'checkbox':
-            $this->_config->$settingName = !empty($this->_params[$settingName]) ? 1 : 0;
-            break;
-
-          case 'text':
-          case 'select':
-          case 'radio':
-          case 'YesNo':
-          case 'entity_reference':
-            $this->_config->$settingName = CRM_Utils_Array::value($settingName, $this->_params);
-            break;
-
-          case 'textarea':
-            $value = CRM_Utils_Array::value($settingName, $this->_params);
-            if ($value) {
-              $value = trim($value);
-              $value = str_replace(["\r\n", "\r"], "\n", $value);
-            }
-            $this->_config->$settingName = $value;
-            break;
-        }
-      }
-    }
-
-    foreach ($this->_varNames as $groupName => $groupValues) {
-      foreach ($groupValues as $settingName => $fieldValue) {
-        $settingValue = isset($this->_config->$settingName) ? $this->_config->$settingName : NULL;
-        Civi::settings()->set($settingName, $settingValue);
-      }
-    }
     // Update any settings stored in dynamic js
     CRM_Core_Resources::singleton()->resetCacheCode();