Introduce new `communication_style` field for Contacts
[civicrm-core.git] / CRM / Contact / Form / Inline / CommunicationPreferences.php
CommitLineData
6a488035
TO
1<?php
2/*
3 +--------------------------------------------------------------------+
232624b1 4 | CiviCRM version 4.4 |
6a488035
TO
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2013 |
7 +--------------------------------------------------------------------+
8 | This file is a part of CiviCRM. |
9 | |
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. |
13 | |
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. |
18 | |
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 +--------------------------------------------------------------------+
26*/
27
28/**
29 *
30 * @package CRM
31 * @copyright CiviCRM LLC (c) 2004-2013
32 * $Id$
33 *
34 */
35
36/**
37 * form helper class for communication preferences inline edit section
38 */
39class CRM_Contact_Form_Inline_CommunicationPreferences extends CRM_Contact_Form_Inline {
40
41 /**
42 * build the form elements for communication preferences
43 *
44 * @return void
45 * @access public
46 */
47 public function buildQuickForm() {
48 parent::buildQuickForm();
49 CRM_Contact_Form_Edit_CommunicationPreferences::buildQuickForm($this);
50 $this->addFormRule(array('CRM_Contact_Form_Edit_CommunicationPreferences', 'formRule'), $this);
51 }
52
53 /**
54 * set defaults for the form
55 *
56 * @return array
57 * @access public
58 */
59 public function setDefaultValues() {
60 $defaults = parent::setDefaultValues();
61
62 if (!empty($defaults['preferred_language'])) {
c0c9cd82 63 $defaults['preferred_language'] = CRM_Core_PseudoConstant::getKey('CRM_Contact_DAO_Contact', 'preferred_language', $defaults['preferred_language']);
6a488035
TO
64 }
65
66 // CRM-7119: set preferred_language to default if unset
67 if (empty($defaults['preferred_language'])) {
68 $config = CRM_Core_Config::singleton();
69 $defaults['preferred_language'] = $config->lcMessages;
70 }
71
aa62b355
OB
72 if (empty($defaults['communication_style_id'])) {
73 $defaults['communication_style_id'] = array_pop(CRM_Core_OptionGroup::values('communication_style', TRUE, NULL, NULL, 'AND is_default = 1'));
74 }
75
6a488035
TO
76 foreach (CRM_Contact_BAO_Contact::$_greetingTypes as $greeting) {
77 $name = "{$greeting}_display";
78 $this->assign($name, CRM_Utils_Array::value($name, $defaults));
79 }
80 return $defaults;
81 }
82
83 /**
84 * process the form
85 *
86 * @return void
87 * @access public
88 */
89 public function postProcess() {
90 $params = $this->exportValues();
91
92 // Process / save communication preferences
93
94 // this is a chekbox, so mark false if we dont get a POST value
95 $params['is_opt_out'] = CRM_Utils_Array::value('is_opt_out', $params, FALSE);
96 $params['contact_type'] = $this->_contactType;
97 $params['contact_id'] = $this->_contactId;
98
99 if (!empty($this->_contactSubType)) {
100 $params['contact_sub_type'] = $this->_contactSubType;
101 }
102
103 CRM_Contact_BAO_Contact::create($params);
104
105 $this->response();
106 }
107}