3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.5 |
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2014 |
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-2014
37 * This class generates form components
38 * for previewing Civicrm Profile Group
41 class CRM_UF_Form_AbstractPreview
extends CRM_Core_Form
{
44 * the fields needed to build this form
51 * Set the profile/field structure for this form
53 * @param array $fields list of fields per CRM_Core_BAO_UFGroup::formatUFFields or CRM_Core_BAO_UFGroup::getFields
54 * @param bool $isSingleField
57 public function setProfile($fields, $isSingleField = FALSE, $flag = FALSE) {
59 $this->assign('previewField', $isSingleField);
63 $this->assign('viewOnly', FALSE);
66 $this->assign('viewOnly', TRUE);
69 $this->set('fieldId', NULL);
70 $this->assign("fields", $fields);
71 $this->_fields
= $fields;
75 * Set the default form values
79 * @return array the default array reference
81 function setDefaultValues() {
83 $stateCountryMap = array();
84 foreach ($this->_fields
as $name => $field) {
85 if ($customFieldID = CRM_Core_BAO_CustomField
::getKeyID($field['name'])) {
86 CRM_Core_BAO_CustomField
::setProfileDefaults($customFieldID, $name, $defaults, NULL, CRM_Profile_Form
::MODE_REGISTER
);
90 if ((substr($name, 0, 14) === 'state_province') ||
(substr($name, 0, 7) === 'country') ||
(substr($name, 0, 6) === 'county')) {
91 list($fieldName, $index) = CRM_Utils_System
::explode('-', $name, 2);
92 if (!array_key_exists($index, $stateCountryMap)) {
93 $stateCountryMap[$index] = array();
95 $stateCountryMap[$index][$fieldName] = $name;
99 // also take care of state country widget
100 if (!empty($stateCountryMap)) {
101 CRM_Core_BAO_Address
::addStateCountryMap($stateCountryMap, $defaults);
104 //set default for country.
105 CRM_Core_BAO_UFGroup
::setRegisterDefaults($this->_fields
, $defaults);
107 // now fix all state country selectors
108 CRM_Core_BAO_Address
::fixAllStateSelects($this, $defaults);
114 * Function to actually build the form
119 public function buildQuickForm() {
120 foreach ($this->_fields
as $name => $field) {
121 if (empty($field['is_view'])) {
122 CRM_Core_BAO_UFGroup
::buildProfile($this, $field, CRM_Profile_Form
::MODE_CREATE
);
127 public function getTemplateFileName() {
128 return 'CRM/UF/Form/Preview.tpl';