3 +--------------------------------------------------------------------+
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2019 |
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-2019
33 class CRM_Contact_Form_Location
{
36 * Set variables up before form is built.
38 * @param CRM_Core_Form $form
40 public static function preProcess(&$form) {
41 $form->_addBlockName
= CRM_Utils_Request
::retrieve('block', 'String');
42 $additionalblockCount = CRM_Utils_Request
::retrieve('count', 'Positive');
44 $form->assign('addBlock', FALSE);
45 if ($form->_addBlockName
&& $additionalblockCount) {
46 $form->assign('addBlock', TRUE);
47 $form->assign('blockName', $form->_addBlockName
);
48 $form->assign('blockId', $additionalblockCount);
49 $form->set($form->_addBlockName
. '_Block_Count', $additionalblockCount);
52 if (is_a($form, 'CRM_Event_Form_ManageEvent_Location')
53 ||
is_a($form, 'CRM_Contact_Form_Domain')) {
55 'Address' => ts('Address'),
56 'Email' => ts('Email'),
57 'Phone' => ts('Phone'),
61 $form->assign('blocks', $form->_blocks
);
62 $form->assign('className', CRM_Utils_System
::getClassName($form));
64 // get address sequence.
65 if (!$addressSequence = $form->get('addressSequence')) {
66 $addressSequence = CRM_Core_BAO_Address
::addressSequence();
67 $form->set('addressSequence', $addressSequence);
69 $form->assign('addressSequence', $addressSequence);
73 * Build the form object.
75 * @param CRM_Core_Form $form
77 public static function buildQuickForm(&$form) {
78 // required for subsequent AJAX requests.
79 $ajaxRequestBlocks = [];
80 $generateAjaxRequest = 0;
82 //build 1 instance of all blocks, without using ajax ...
83 foreach ($form->_blocks
as $blockName => $label) {
84 $name = strtolower($blockName);
87 if (!empty($_POST[$name]) && is_array($_POST[$name])) {
88 $instances = array_keys($_POST[$name]);
90 elseif (property_exists($form, '_values') && !empty($form->_values
[$name]) && is_array($form->_values
[$name])) {
91 $instances = array_keys($form->_values
[$name]);
94 foreach ($instances as $instance) {
96 $form->assign('addBlock', FALSE);
97 $form->assign('blockId', $instance);
100 //we are going to build other block instances w/ AJAX
101 $generateAjaxRequest++
;
102 $ajaxRequestBlocks[$blockName][$instance] = TRUE;
105 $form->set($blockName . '_Block_Count', $instance);
106 $formName = 'CRM_Contact_Form_Edit_' . $blockName;
107 $formName::buildQuickForm($form);
111 //assign to generate AJAX request for building extra blocks.
112 $form->assign('generateAjaxRequest', $generateAjaxRequest);
113 $form->assign('ajaxRequestBlocks', $ajaxRequestBlocks);