3 +--------------------------------------------------------------------+
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2018 |
7 +--------------------------------------------------------------------+
8 | This file is a part of CiviCRM. |
10 | CiviCRM is free software; you can copy, modify, and distribute it |
11 | under the terms of the GNU Affero General Public License |
12 | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
14 | CiviCRM is distributed in the hope that it will be useful, but |
15 | WITHOUT ANY WARRANTY; without even the implied warranty of |
16 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
17 | See the GNU Affero General Public License for more details. |
19 | You should have received a copy of the GNU Affero General Public |
20 | License and the CiviCRM Licensing Exception along |
21 | with this program; if not, contact CiviCRM LLC |
22 | at info[AT]civicrm[DOT]org. If you have questions about the |
23 | GNU Affero General Public License or the licensing of CiviCRM, |
24 | see the CiviCRM license FAQ at http://civicrm.org/licensing |
25 +--------------------------------------------------------------------+
31 * @copyright CiviCRM LLC (c) 2004-2018
35 * This trait allows us to consolidate Preferences & Settings forms.
37 * It is intended mostly as part of a refactoring process to get rid of having 2.
39 trait CRM_Admin_Form_SettingTrait
{
44 protected $settingsMetadata;
51 public function getDefaultEntity() {
56 * Get the metadata relating to the settings on the form, ordered by the keys in $this->_settings.
60 protected function getSettingsMetaData() {
61 if (empty($this->settingsMetadata
)) {
62 $allSettingMetaData = civicrm_api3('setting', 'getfields', []);
63 $this->settingsMetadata
= array_intersect_key($allSettingMetaData['values'], $this->_settings
);
64 // This array_merge re-orders to the key order of $this->_settings.
65 $this->settingsMetadata
= array_merge($this->_settings
, $this->settingsMetadata
);
67 return $this->settingsMetadata
;
71 * Get the settings which can be stored based on metadata.
73 * @param array $params
76 protected function getSettingsToSetByMetadata($params) {
77 return array_intersect_key($params, $this->_settings
);
83 protected function filterParamsSetByMetadata(&$params) {
84 foreach ($this->getSettingsToSetByMetadata($params) as $setting => $settingGroup) {
85 //@todo array_diff this
86 unset($params[$setting]);
91 * Add fields in the metadata to the template.
93 protected function addFieldsDefinedInSettingsMetadata() {
94 $settingMetaData = $this->getSettingsMetaData();
96 foreach ($settingMetaData as $setting => $props) {
97 if (isset($props['quick_form_type'])) {
98 if (isset($props['pseudoconstant'])) {
99 $options = civicrm_api3('Setting', 'getoptions', [
106 //Load input as readonly whose values are overridden in civicrm.settings.php.
107 if (Civi
::settings()->getMandatory($setting)) {
108 $props['html_attributes']['readonly'] = TRUE;
109 $this->includesReadOnlyFields
= TRUE;
112 $add = 'add' . $props['quick_form_type'];
113 if ($add == 'addElement') {
118 ($options !== NULL) ?
$options['values'] : CRM_Utils_Array
::value('html_attributes', $props, []),
119 ($options !== NULL) ? CRM_Utils_Array
::value('html_attributes', $props, []) : NULL
122 elseif ($add == 'addSelect') {
123 $this->addElement('select', $setting, ts($props['title']), $options['values'], CRM_Utils_Array
::value('html_attributes', $props));
125 elseif ($add == 'addCheckBox') {
126 $this->addCheckBox($setting, ts($props['title']), $options['values'], NULL, CRM_Utils_Array
::value('html_attributes', $props), NULL, NULL, [' ']);
128 elseif ($add == 'addChainSelect') {
129 $this->addChainSelect($setting, [
130 'label' => ts($props['title']),
133 elseif ($add == 'addMonthDay') {
134 $this->add('date', $setting, ts($props['title']), CRM_Core_SelectValues
::date(NULL, 'M d'));
137 $this->$add($setting, ts($props['title']));
139 // Migrate to using an array as easier in smart...
140 $descriptions[$setting] = ts($props['description']);
141 $this->assign("{$setting}_description", ts($props['description']));
142 if ($setting == 'max_attachments') {
143 //temp hack @todo fix to get from metadata
144 $this->addRule('max_attachments', ts('Value should be a positive number'), 'positiveInteger');
146 if ($setting == 'maxFileSize') {
148 $this->addRule('maxFileSize', ts('Value should be a positive number'), 'positiveInteger');
153 // setting_description should be deprecated - see Mail.tpl for metadata based tpl.
154 $this->assign('setting_descriptions', $descriptions);
155 $this->assign('settings_fields', $settingMetaData);