Merge pull request #2793 from monishdeb/HR-322
[civicrm-core.git] / CRM / Contribute / Form / SoftCredit.php
CommitLineData
0baed70b 1<?php
2/*
3 +--------------------------------------------------------------------+
06b69b18 4 | CiviCRM version 4.5 |
0baed70b 5 +--------------------------------------------------------------------+
06b69b18 6 | Copyright CiviCRM LLC (c) 2004-2014 |
0baed70b 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
06b69b18 31 * @copyright CiviCRM LLC (c) 2004-2014
0baed70b 32 * $Id$
33 *
34 */
35
36/**
37 * This class build form elements for select exitsing or create new soft block
38 */
39class CRM_Contribute_Form_SoftCredit {
40
1421174e 41 /**
42 * Function to set variables up before form is built
43 *
44 * @return void
45 * @access static
46 */
47 static function preProcess(&$form) {
48 $contriDAO = new CRM_Contribute_DAO_Contribution();
49 $contriDAO->id = $form->_id;
50 $contriDAO->find(TRUE);
51 if ($contriDAO->contribution_page_id) {
52 $ufJoinParams = array(
53 'module' => 'soft_credit',
54 'entity_table' => 'civicrm_contribution_page',
55 'entity_id' => $contriDAO->contribution_page_id,
56 );
57 $profileId = CRM_Core_BAO_UFJoin::getUFGroupIds($ufJoinParams);
58
59 //check if any honree profile is enabled if yes then assign its profile type to $_honoreeProfileType
60 // which will be used to constraint soft-credit contact type in formRule, CRM-13981
61 if ($profileId[0]) {
62 $form->_honoreeProfileType = CRM_Core_BAO_UFGroup::getContactType($profileId[0]);
63 }
64 }
65 }
66
67
0baed70b 68 /**
69 * Function used to build form element for soft credit block
70 *
ccec9d6b 71 * @param CRM_Core_Form $form
0baed70b 72 * @access public
73 *
74 * @return void
75 */
76 static function buildQuickForm(&$form) {
8af73472 77 if ($form->_mode == 'live' && $form->_honor_block_is_active) {
133e2c99 78 $ufJoinDAO = new CRM_Core_DAO_UFJoin();
79 $ufJoinDAO->module = 'soft_credit';
80 $ufJoinDAO->entity_id = $form->_id;
81 if ($ufJoinDAO->find(TRUE)) {
ba60f73e 82 $jsonData = CRM_Contribute_BAO_ContributionPage::formatMultilingualHonorParams($ufJoinDAO->module_data, TRUE);
133e2c99 83 if ($jsonData) {
ba60f73e 84 foreach (array('honor_block_title', 'honor_block_text') as $name) {
85 $form->assign($name, $jsonData[$name]);
86 }
133e2c99 87
88 $softCreditTypes = CRM_Core_OptionGroup::values("soft_credit_type", FALSE);
89 $extraOption = array('onclick' => "enableHonorType();");
90
91 // radio button for Honor Type
ba60f73e 92 foreach ($jsonData['soft_credit_types'] as $value) {
133e2c99 93 $honorTypes[$value] = $form->createElement('radio', NULL, NULL, $softCreditTypes[$value], $value, $extraOption);
94 }
95 $form->addGroup($honorTypes, 'soft_credit_type_id', NULL);
96 }
97 }
98 return $form;
99 }
100
65377546 101 // by default generate 5 blocks
17db9f82
KJ
102 $item_count = 6;
103
35729234 104 $showSoftCreditRow = 2;
1eb70457 105 if ($form->getAction() & CRM_Core_Action::UPDATE) {
7ccf8829 106 $form->_softCreditInfo = CRM_Contribute_BAO_ContributionSoft::getSoftContribution($form->_id, TRUE);
133e2c99 107 }
108 elseif ($form->_pledgeID) {
109 //Check and select most recent completed contrubtion and use it to retrieve
110 //soft-credit information to use as default for current pledge payment, CRM-13981
111 $pledgePayments = CRM_Pledge_BAO_PledgePayment::getPledgePayments($form->_pledgeID);
112 foreach ($pledgePayments as $id => $record) {
113 if ($record['contribution_id']) {
114 $softCredits = CRM_Contribute_BAO_ContributionSoft::getSoftContribution($record['contribution_id'], TRUE);
115 if ($record['status'] == 'Completed' && count($softCredits) > 0) {
116 $form->_softCreditInfo = $softCredits;
117 }
118 }
119 }
120 }
121
122 if (property_exists($form, "_softCreditInfo")) {
35729234
KJ
123 if (!empty($form->_softCreditInfo['soft_credit'])) {
124 $showSoftCreditRow = count($form->_softCreditInfo['soft_credit']);
125 $showSoftCreditRow++;
35729234 126 }
17db9f82
KJ
127 }
128
129 for ($rowNumber = 1; $rowNumber <= $item_count; $rowNumber++) {
ccec9d6b 130 $form->addEntityRef("soft_credit_contact_id[{$rowNumber}]", ts('Contact'), array('create' => TRUE));
d4a9a18a 131
ccec9d6b 132 $form->addMoney("soft_credit_amount[{$rowNumber}]", ts('Amount'), FALSE, NULL, FALSE);
51fa20cb 133
ccec9d6b 134 $form->addSelect("soft_credit_type[{$rowNumber}]", array('entity' => 'contribution_soft', 'field' => 'soft_credit_type_id', 'label' => ts('Type')));
d4a9a18a 135 if (!empty($form->_softCreditInfo['soft_credit'][$rowNumber]['soft_credit_id'])) {
ccec9d6b 136 $form->add('hidden', "soft_credit_id[{$rowNumber}]",
d4a9a18a
KJ
137 $form->_softCreditInfo['soft_credit'][$rowNumber]['soft_credit_id']);
138 }
0baed70b 139 }
0baed70b 140
e41cebea 141 // CRM-7368 allow user to set or edit PCP link for contributions
142 $siteHasPCPs = CRM_Contribute_PseudoConstant::pcPage();
143 if (!CRM_Utils_Array::crmIsEmptyArray($siteHasPCPs)) {
144 $form->assign('siteHasPCPs', 1);
6bb107ce
CW
145 $form->add('hidden', 'pcp_made_through'); // stores the label
146 $form->add('text', 'pcp_made_through_id', ts('Credit to a Personal Campaign Page'), array('class' => 'twenty'));
e41cebea 147 $form->addElement('checkbox', 'pcp_display_in_roll', ts('Display in Honor Roll?'), NULL);
148 $form->addElement('text', 'pcp_roll_nickname', ts('Name (for Honor Roll)'));
149 $form->addElement('textarea', 'pcp_personal_note', ts('Personal Note (for Honor Roll)'));
150 }
17db9f82
KJ
151 $form->assign('showSoftCreditRow', $showSoftCreditRow);
152 $form->assign('rowCount', $item_count);
51fa20cb 153 $form->addElement('hidden', 'sct_default_id',
ccec9d6b 154 CRM_Core_OptionGroup::getDefaultValue("soft_credit_type"),
51fa20cb 155 array('id' => 'sct_default_id')
156 );
0baed70b 157 }
dfbad3f7
KJ
158
159 /**
160 * Function used to set defaults for soft credit block
161 */
17db9f82 162 static function setDefaultValues(&$defaults, &$form) {
35729234 163 if (!empty($form->_softCreditInfo['soft_credit'])) {
c7e376bf 164 foreach ($form->_softCreditInfo['soft_credit'] as $key => $value) {
0689c15c 165 $defaults["soft_credit_amount[$key]"] = CRM_Utils_Money::format($value['amount'], NULL, '%a');
ccec9d6b 166 $defaults["soft_credit_contact_id[$key]"] = $value['contact_id'];
51fa20cb 167 $defaults["soft_credit_type[$key]"] = $value['soft_credit_type'];
35729234
KJ
168 }
169 }
b6545333 170 if (!empty($form->_softCreditInfo['pcp_id'])) {
76ca3345 171 $pcpInfo = $form->_softCreditInfo;
17db9f82 172 $pcpId = CRM_Utils_Array::value('pcp_id', $pcpInfo);
dfbad3f7
KJ
173 $pcpTitle = CRM_Core_DAO::getFieldValue('CRM_PCP_DAO_PCP', $pcpId, 'title');
174 $contributionPageTitle = CRM_PCP_BAO_PCP::getPcpPageTitle($pcpId, 'contribute');
d4a9a18a
KJ
175 $defaults['pcp_made_through'] = CRM_Utils_Array::value('sort_name', $pcpInfo) . " :: " . $pcpTitle . " :: " . $contributionPageTitle;
176 $defaults['pcp_made_through_id'] = CRM_Utils_Array::value('pcp_id', $pcpInfo);
177 $defaults['pcp_display_in_roll'] = CRM_Utils_Array::value('pcp_display_in_roll', $pcpInfo);
178 $defaults['pcp_roll_nickname'] = CRM_Utils_Array::value('pcp_roll_nickname', $pcpInfo);
179 $defaults['pcp_personal_note'] = CRM_Utils_Array::value('pcp_personal_note', $pcpInfo);
dfbad3f7 180 }
dfbad3f7 181 }
ac0c89ed 182
183 /**
184 * global form rule
185 *
186 * @param array $fields the input form values
187 *
188 * @return true if no errors, else array of errors
189 * @access public
190 * @static
191 */
b326919b 192 static function formRule($fields, $errors, $self) {
ac0c89ed 193 $errors = array();
194
195 // if honor roll fields are populated but no PCP is selected
a7488080 196 if (empty($fields['pcp_made_through_id'])) {
8cc574cf 197 if (!empty($fields['pcp_display_in_roll']) || !empty($fields['pcp_roll_nickname']) ||
ac0c89ed 198 CRM_Utils_Array::value('pcp_personal_note', $fields)
199 ) {
6bb107ce 200 $errors['pcp_made_through_id'] = ts('Please select a Personal Campaign Page, OR uncheck Display in Honor Roll and clear both the Honor Roll Name and the Personal Note field.');
ac0c89ed 201 }
202 }
203
204 if (!empty($fields['soft_credit_amount'])) {
ccec9d6b 205 $repeat = array_count_values($fields['soft_credit_contact_id']);
ac0c89ed 206 foreach ($fields['soft_credit_amount'] as $key => $val) {
ccec9d6b
CW
207 if (!empty($fields['soft_credit_contact_id'][$key])) {
208 if ($repeat[$fields['soft_credit_contact_id'][$key]] > 1) {
1421174e 209 $errors["soft_credit_contact[$key]"] = ts('You cannot enter multiple soft credits for the same contact.');
ac0c89ed 210 }
b326919b 211 if ($self->_action == CRM_Core_Action::ADD && $fields['soft_credit_amount'][$key]
0689c15c 212 && (CRM_Utils_Rule::cleanMoney($fields['soft_credit_amount'][$key]) > CRM_Utils_Rule::cleanMoney($fields['total_amount']))) {
ac0c89ed 213 $errors["soft_credit_amount[$key]"] = ts('Soft credit amount cannot be more than the total amount.');
214 }
215 if (empty($fields['soft_credit_amount'][$key])) {
216 $errors["soft_credit_amount[$key]"] = ts('Please enter the soft credit amount.');
217 }
ccec9d6b 218 $contactType = CRM_Contact_BAO_Contact::getContactType($fields['soft_credit_contact_id'][$key]);
1421174e 219 if ($self->_honoreeProfileType && $self->_honoreeProfileType != $contactType) {
220 $errors["soft_credit_contact[$key]"] = ts('Please choose a contact of type %1', array(1 => $self->_honoreeProfileType));
221 }
ac0c89ed 222 }
223 }
224 }
1421174e 225
ac0c89ed 226 return $errors;
227 }
0baed70b 228}
229