3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.6 |
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 * Auxilary 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 form object
48 * @param int $inlineEditMode ( 1 for contact summary
49 * top bar form and 2 for display name edit )
53 public static function buildQuickForm(&$form, $inlineEditMode = NULL) {
54 $attributes = CRM_Core_DAO
::getAttribute('CRM_Contact_DAO_Contact');
56 $form->applyFilter('__ALL__', 'trim');
58 if ( !$inlineEditMode ||
$inlineEditMode == 1 ) {
60 $form->add('text', 'household_name', ts('Household Name'), $attributes['household_name']);
63 if ( !$inlineEditMode ||
$inlineEditMode == 2 ) {
65 $form->addElement('text', 'nick_name', ts('Nickname'), $attributes['nick_name']);
66 $form->addElement('text', 'contact_source', ts('Source'), CRM_Utils_Array
::value('source', $attributes));
69 if ( !$inlineEditMode ) {
70 $form->add('text', 'external_identifier', ts('External ID'), $attributes['external_identifier'], FALSE);
71 $form->addRule('external_identifier',
72 ts('External ID already exists in Database.'),
74 array('CRM_Contact_DAO_Contact', $form->_contactId
, 'external_identifier')
80 * Add rule for household
82 * @param array $fields array of form values
83 * @param array $files - unused
84 * @param int $contactID
86 * @return array|bool $error@static
88 public static function formRule($fields, $files, $contactID = NULL) {
90 $primaryID = CRM_Contact_Form_Contact
::formRule($fields, $errors, $contactID);
92 // make sure that household name is set
93 if (empty($fields['household_name'])) {
94 $errors['household_name'] = 'Household Name should be set.';
97 //check for duplicate - dedupe rules
98 CRM_Contact_Form_Contact
::checkDuplicateContacts($fields, $errors, $contactID, 'Household');
100 return empty($errors) ?
TRUE : $errors;