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
37 * this class builds custom data
39 class CRM_Custom_Form_CustomData
{
42 * @param CRM_Core_Form $form
43 * @param null|string $subName
44 * @param null|string $subType
45 * @param null|int $groupCount
47 * @param null|int $entityID
48 * @param null $onlySubType
50 public static function preProcess(
51 &$form, $subName = NULL, $subType = NULL,
52 $groupCount = NULL, $type = NULL, $entityID = NULL, $onlySubType = NULL
58 $form->_type
= CRM_Utils_Request
::retrieve('type', 'String', $form);
61 if (isset($subType)) {
62 $form->_subType
= $subType;
65 $form->_subType
= CRM_Utils_Request
::retrieve('subType', 'String', $form);
68 if ($form->_subType
== 'null') {
69 $form->_subType
= NULL;
72 if (isset($subName)) {
73 $form->_subName
= $subName;
76 $form->_subName
= CRM_Utils_Request
::retrieve('subName', 'String', $form);
79 if ($form->_subName
== 'null') {
80 $form->_subName
= NULL;
84 $form->_groupCount
= $groupCount;
87 $form->_groupCount
= CRM_Utils_Request
::retrieve('cgcount', 'Positive', $form);
90 $form->assign('cgCount', $form->_groupCount
);
92 //carry qf key, since this form is not inhereting core form.
93 if ($qfKey = CRM_Utils_Request
::retrieve('qfKey', 'String')) {
94 $form->assign('qfKey', $qfKey);
98 $form->_entityId
= $entityID;
101 $form->_entityId
= CRM_Utils_Request
::retrieve('entityID', 'Positive', $form);
104 $typeCheck = CRM_Utils_Request
::retrieve('type', 'String');
105 $urlGroupId = CRM_Utils_Request
::retrieve('groupID', 'Positive');
106 if (isset($typeCheck) && $urlGroupId) {
107 $form->_groupID
= $urlGroupId;
110 $form->_groupID
= CRM_Utils_Request
::retrieve('groupID', 'Positive', $form);
113 $gid = (isset($form->_groupID
)) ?
$form->_groupID
: NULL;
114 $getCachedTree = isset($form->_getCachedTree
) ?
$form->_getCachedTree
: TRUE;
116 $subType = $form->_subType
;
117 if (!is_array($subType) && strstr($subType, CRM_Core_DAO
::VALUE_SEPARATOR
)) {
118 $subType = str_replace(CRM_Core_DAO
::VALUE_SEPARATOR
, ',', trim($subType, CRM_Core_DAO
::VALUE_SEPARATOR
));
121 self
::setGroupTree($form, $subType, $gid, $onlySubType, $getCachedTree);
125 * @param CRM_Core_Form $form
129 public static function setDefaultValues(&$form) {
131 CRM_Core_BAO_CustomGroup
::setDefaults($form->_groupTree
, $defaults, FALSE, FALSE, $form->get('action'));
136 * @param CRM_Core_Form $form
138 public static function buildQuickForm(&$form) {
139 $form->addElement('hidden', 'hidden_custom', 1);
140 $form->addElement('hidden', "hidden_custom_group_count[{$form->_groupID}]", $form->_groupCount
);
141 CRM_Core_BAO_CustomGroup
::buildQuickForm($form, $form->_groupTree
);
148 * @param $onlySubType
149 * @param $getCachedTree
153 public static function setGroupTree(&$form, $subType, $gid, $onlySubType = NULL, $getCachedTree = FALSE) {
154 $singleRecord = NULL;
155 if (!empty($form->_groupCount
) && !empty($form->_multiRecordDisplay
) && $form->_multiRecordDisplay
== 'single') {
156 $singleRecord = $form->_groupCount
;
158 $mode = CRM_Utils_Request
::retrieve('mode', 'String', $form);
159 // when a new record is being added for multivalued custom fields.
160 if (isset($form->_groupCount
) && $form->_groupCount
== 0 && $mode == 'add' &&
161 !empty($form->_multiRecordDisplay
) && $form->_multiRecordDisplay
== 'single') {
162 $singleRecord = 'new';
165 $groupTree = CRM_Core_BAO_CustomGroup
::getTree($form->_type
,
178 if (property_exists($form, '_customValueCount') && !empty($groupTree)) {
179 $form->_customValueCount
= CRM_Core_BAO_CustomGroup
::buildCustomDataView($form, $groupTree, TRUE, NULL, NULL, NULL, $form->_entityId
);
181 // we should use simplified formatted groupTree
182 $groupTree = CRM_Core_BAO_CustomGroup
::formatGroupTree($groupTree, $form->_groupCount
, $form);
184 if (isset($form->_groupTree
) && is_array($form->_groupTree
)) {
185 $keys = array_keys($groupTree);
186 foreach ($keys as $key) {
187 $form->_groupTree
[$key] = $groupTree[$key];
189 return array($form, $groupTree);
192 $form->_groupTree
= $groupTree;
193 return array($form, $groupTree);