3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.6 |
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2015 |
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-2015
37 * Auxiliary class to provide support to the Contact Form class. Does this by implementing
38 * a small set of static methods
41 class CRM_Contact_Form_Edit_Household
{
44 * This function provides the HTML form elements that are specific.
45 * to the Household Contact Type
47 * @param CRM_Core_Form $form
49 * @param int $inlineEditMode
50 * ( 1 for contact summary.
51 * top bar form and 2 for display name edit )
55 public static function buildQuickForm(&$form, $inlineEditMode = NULL) {
56 $attributes = CRM_Core_DAO
::getAttribute('CRM_Contact_DAO_Contact');
58 $form->applyFilter('__ALL__', 'trim');
60 if (!$inlineEditMode ||
$inlineEditMode == 1) {
62 $form->add('text', 'household_name', ts('Household Name'), $attributes['household_name']);
65 if (!$inlineEditMode ||
$inlineEditMode == 2) {
67 $form->addElement('text', 'nick_name', ts('Nickname'), $attributes['nick_name']);
68 $form->addElement('text', 'contact_source', ts('Source'), CRM_Utils_Array
::value('source', $attributes));
71 if (!$inlineEditMode) {
72 $form->add('text', 'external_identifier', ts('External ID'), $attributes['external_identifier'], FALSE);
73 $form->addRule('external_identifier',
74 ts('External ID already exists in Database.'),
76 array('CRM_Contact_DAO_Contact', $form->_contactId
, 'external_identifier')
82 * Add rule for household.
84 * @param array $fields
85 * Array of form values.
88 * @param int $contactID
93 public static function formRule($fields, $files, $contactID = NULL) {
95 $primaryID = CRM_Contact_Form_Contact
::formRule($fields, $errors, $contactID);
97 // make sure that household name is set
98 if (empty($fields['household_name'])) {
99 $errors['household_name'] = 'Household Name should be set.';
102 //check for duplicate - dedupe rules
103 CRM_Contact_Form_Contact
::checkDuplicateContacts($fields, $errors, $contactID, 'Household');
105 return empty($errors) ?
TRUE : $errors;