(NFC) Update CRM/Friend CRM/Grant CRM/Group CRM/Mailing to be up to date to a future...
[civicrm-core.git] / CRM / Friend / Form.php
CommitLineData
6a488035
TO
1<?php
2/*
3 +--------------------------------------------------------------------+
fee14197 4 | CiviCRM version 5 |
6a488035 5 +--------------------------------------------------------------------+
6b83d5bd 6 | Copyright CiviCRM LLC (c) 2004-2019 |
6a488035
TO
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 +--------------------------------------------------------------------+
d25dd0ee 26 */
6a488035
TO
27
28/**
29 *
30 * @package CRM
6b83d5bd 31 * @copyright CiviCRM LLC (c) 2004-2019
6a488035
TO
32 * $Id$
33 *
34 */
35
36/**
37 * This class generates form components for Tell A Friend Form For End User
38 *
39 */
40class CRM_Friend_Form extends CRM_Core_Form {
41
42 /**
fe482240 43 * Constants for number of friend contacts.
6a488035 44 */
7da04cde 45 const NUM_OPTION = 3;
6a488035
TO
46
47 /**
4d0bbeb4 48 * The id of the entity that we are processing.
6a488035
TO
49 *
50 * @var int
6a488035
TO
51 */
52 protected $_entityId;
53
54 /**
4d0bbeb4
MW
55 * Tell a friend id in db.
56 *
57 * @var int
58 */
59 public $_friendId;
60
61 /**
62 * The table name of the entity that we are processing.
6a488035
TO
63 *
64 * @var string
6a488035
TO
65 */
66 protected $_entityTable;
67
68 protected $_campaignId;
69
70 /**
fe482240 71 * The contact ID.
6a488035
TO
72 *
73 * @var int
6a488035
TO
74 */
75 protected $_contactID;
76
77 public function preProcess() {
78 $this->_action = CRM_Utils_Request::retrieve('action', 'String', $this);
79 $this->_entityId = CRM_Utils_Request::retrieve('eid', 'Positive', $this, TRUE);
80
81 $pcomponent = CRM_Utils_Request::retrieve('pcomponent', 'String', $this, TRUE);
82
be2fb01f 83 if (in_array($pcomponent, [
353ffa53 84 'contribute',
317fceb4 85 'event',
be2fb01f
CW
86 ])) {
87 $values = [];
88 $params = ['id' => $this->_entityId];
6a488035 89 CRM_Core_DAO::commonRetrieve('CRM_Contribute_DAO_ContributionPage',
be2fb01f 90 $params, $values, ['title', 'campaign_id', 'is_share']
6a488035 91 );
353ffa53
TO
92 $this->_title = CRM_Utils_Array::value('title', $values);
93 $this->_campaignId = CRM_Utils_Array::value('campaign_id', $values);
6a488035
TO
94 $this->_entityTable = 'civicrm_contribution_page';
95 if ($pcomponent == 'event') {
96 $this->_entityTable = 'civicrm_event';
97 $isShare = CRM_Core_DAO::getFieldValue('CRM_Event_DAO_Event', $this->_entityId, 'is_share');
8c2b0ce2 98 $this->_title = CRM_Core_DAO::getFieldValue('CRM_Event_DAO_Event', $this->_entityId, 'title');
0db6c3e1
TO
99 }
100 else {
03e04002 101 $isShare = CRM_Utils_Array::value('is_share', $values);
6a488035
TO
102 }
103 // Tell Form.tpl whether to include SocialNetwork.tpl for social media sharing
104 $this->assign('isShare', $isShare);
105 }
106 elseif ($pcomponent == 'pcp') {
107 $this->_pcpBlockId = CRM_Utils_Request::retrieve('blockId', 'Positive', $this, TRUE);
108
be2fb01f
CW
109 $values = [];
110 $params = ['id' => $this->_pcpBlockId];
6a488035 111 CRM_Core_DAO::commonRetrieve('CRM_PCP_DAO_PCPBlock',
be2fb01f 112 $params, $values, ['is_tellfriend_enabled', 'tellfriend_limit']
6a488035
TO
113 );
114
a7488080 115 if (empty($values['is_tellfriend_enabled'])) {
6a488035
TO
116 CRM_Core_Error::fatal(ts('Tell Friend is disable for this Personal Campaign Page'));
117 }
118
119 $this->_mailLimit = $values['tellfriend_limit'];
120 $this->_entityTable = 'civicrm_pcp';
121
122 $sql = '
03e04002 123 SELECT pcp.title,
6a488035
TO
124 contrib.campaign_id
125 FROM civicrm_pcp pcp
03e04002 126 INNER JOIN civicrm_contribution_page contrib ON ( pcp.page_id = contrib.id AND pcp.page_type = "contribute" )
6a488035 127 WHERE pcp.id = %1';
be2fb01f 128 $pcp = CRM_Core_DAO::executeQuery($sql, [1 => [$this->_entityId, 'Positive']]);
6a488035
TO
129 while ($pcp->fetch()) {
130 $this->_title = $pcp->title;
131 $this->_campaignId = $pcp->campaign_id;
132 $pcp->free();
133 }
134
135 $this->assign('pcpTitle', $this->_title);
136 }
137 else {
138 CRM_Core_Error::fatal(ts('page argument missing or invalid'));
139 }
140 $this->assign('context', $pcomponent);
141
142 $session = CRM_Core_Session::singleton();
143 $this->_contactID = $session->get('userID');
144 if (!$this->_contactID) {
145 $this->_contactID = $session->get('transaction.userID');
146 }
147
148 if (!$this->_contactID) {
149 CRM_Core_Error::fatal(ts('Could not get the contact ID'));
150 }
151
152 // we do not want to display recently viewed items, so turn off
153 $this->assign('displayRecent', FALSE);
154 }
155
156 /**
c490a46a 157 * Set default values for the form.
6a488035 158 *
6a488035 159 *
355ba699 160 * @return void
6a488035
TO
161 */
162 public function setDefaultValues() {
be2fb01f 163 $defaults = [];
6a488035
TO
164
165 $defaults['entity_id'] = $this->_entityId;
166 $defaults['entity_table'] = $this->_entityTable;
167
168 CRM_Friend_BAO_Friend::getValues($defaults);
169 CRM_Utils_System::setTitle(CRM_Utils_Array::value('title', $defaults));
170
171 $this->assign('title', CRM_Utils_Array::value('title', $defaults));
172 $this->assign('intro', CRM_Utils_Array::value('intro', $defaults));
173 $this->assign('message', CRM_Utils_Array::value('suggested_message', $defaults));
174 $this->assign('entityID', $this->_entityId);
175
176 list($fromName, $fromEmail) = CRM_Contact_BAO_Contact::getContactDetails($this->_contactID);
177
178 $defaults['from_name'] = $fromName;
179 $defaults['from_email'] = $fromEmail;
180
181 return $defaults;
182 }
183
184 /**
fe482240 185 * Build the form object.
6a488035 186 *
355ba699 187 * @return void
6a488035
TO
188 */
189 public function buildQuickForm() {
ef328ad5 190 $this->applyFilter('__ALL__', 'trim');
6a488035
TO
191 // Details of User
192 $name = &$this->add('text',
193 'from_name',
194 ts('From'),
195 CRM_Core_DAO::getAttribute('CRM_Contact_DAO_Contact', 'first_name')
196 );
197 $name->freeze();
198
199 $email = &$this->add('text',
200 'from_email',
201 ts('Your Email'),
202 CRM_Core_DAO::getAttribute('CRM_Core_DAO_Email', 'email'),
203 TRUE
204 );
205 $email->freeze();
206
5d51a2f9 207 $this->add('wysiwyg', 'suggested_message', ts('Your Message'), CRM_Core_DAO::getAttribute('CRM_Friend_DAO_Friend', 'suggested_message'));
be2fb01f 208 $friend = [];
6a488035
TO
209 $mailLimit = self::NUM_OPTION;
210 if ($this->_entityTable == 'civicrm_pcp') {
211 $mailLimit = $this->_mailLimit;
212 }
213 $this->assign('mailLimit', $mailLimit + 1);
214 for ($i = 1; $i <= $mailLimit; $i++) {
215 $this->add('text', "friend[$i][first_name]", ts("Friend's First Name"));
216 $this->add('text', "friend[$i][last_name]", ts("Friend's Last Name"));
217 $this->add('text', "friend[$i][email]", ts("Friend's Email"));
218 $this->addRule("friend[$i][email]", ts('The format of this email address is not valid.'), 'email');
219 }
220
be2fb01f 221 $this->addButtons([
7e8c8317
SL
222 [
223 'type' => 'submit',
224 'name' => ts('Send Your Message'),
225 'spacing' => '&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;',
226 'isDefault' => TRUE,
227 ],
228 [
229 'type' => 'cancel',
230 'name' => ts('Cancel'),
231 ],
232 ]);
6a488035 233
be2fb01f 234 $this->addFormRule(['CRM_Friend_Form', 'formRule']);
6a488035
TO
235 }
236
237 /**
fe482240 238 * Validation.
6a488035 239 *
c490a46a 240 * @param array $fields
6a488035 241 *
72b3a70c
CW
242 * @return bool|array
243 * mixed true or array of errors
6a488035 244 */
00be9182 245 public static function formRule($fields) {
6a488035 246
be2fb01f 247 $errors = [];
6a488035
TO
248
249 $valid = FALSE;
250 foreach ($fields['friend'] as $key => $val) {
251 if (trim($val['first_name']) || trim($val['last_name']) || trim($val['email'])) {
252 $valid = TRUE;
253
254 if (!trim($val['first_name'])) {
255 $errors["friend[{$key}][first_name]"] = ts('Please enter your friend\'s first name.');
256 }
257
258 if (!trim($val['last_name'])) {
259 $errors["friend[{$key}][last_name]"] = ts('Please enter your friend\'s last name.');
260 }
261
262 if (!trim($val['email'])) {
263 $errors["friend[{$key}][email]"] = ts('Please enter your friend\'s email address.');
264 }
265 }
266 }
267
268 if (!$valid) {
269 $errors['friend[1][first_name]'] = ts("Please enter at least one friend's information, or click Cancel if you don't want to send emails at this time.");
270 }
271
272 return empty($errors) ? TRUE : $errors;
273 }
274
275 /**
fe482240 276 * Process the form submission.
6a488035 277 *
6a488035 278 *
355ba699 279 * @return void
6a488035
TO
280 */
281 public function postProcess() {
282 // get the submitted form values.
283 $formValues = $this->controller->exportValues($this->_name);
284
285 $formValues['entity_id'] = $this->_entityId;
286 $formValues['entity_table'] = $this->_entityTable;
287 $formValues['source_contact_id'] = $this->_contactID;
288 $formValues['is_test'] = $this->_action ? 1 : 0;
289 $formValues['title'] = $this->_title;
290 $formValues['campaign_id'] = $this->_campaignId;
291
292 CRM_Friend_BAO_Friend::create($formValues);
293
294 $this->assign('status', 'thankyou');
be2fb01f 295 $defaults = [];
6a488035
TO
296
297 $defaults['entity_id'] = $this->_entityId;
298 $defaults['entity_table'] = $this->_entityTable;
299
300 CRM_Friend_BAO_Friend::getValues($defaults);
301 if ($this->_entityTable == 'civicrm_pcp') {
2b3846c2 302 $defaults['thankyou_text'] = $defaults['thankyou_title'] = ts('Thank you for your support');
6a488035
TO
303 $defaults['thankyou_text'] = ts('Thanks for supporting this campaign by spreading the word to your friends.');
304 }
305 elseif ($this->_entityTable == 'civicrm_contribution_page') {
306 // If this is tell a friend after contributing, give donor link to create their own fundraising page
307 if ($linkText = CRM_PCP_BAO_PCP::getPcpBlockStatus($defaults['entity_id'], $defaults['entity_table'])) {
308
309 $linkTextUrl = CRM_Utils_System::url('civicrm/contribute/campaign',
310 "action=add&reset=1&pageId={$defaults['entity_id']}&component=contribute",
311 FALSE, NULL, TRUE,
312 TRUE
313 );
314 $this->assign('linkTextUrl', $linkTextUrl);
315 $this->assign('linkText', $linkText);
316 }
0db6c3e1 317 }
481a74f4 318 elseif ($this->_entityTable == 'civicrm_event') {
08ffe40c
TO
319 // If this is tell a friend after registering for an event, give donor link to create their own fundraising page
320 require_once 'CRM/PCP/BAO/PCP.php';
481a74f4
TO
321 if ($linkText = CRM_PCP_BAO_PCP::getPcpBlockStatus($defaults['entity_id'], $defaults['entity_table'])) {
322 $linkTextUrl = CRM_Utils_System::url('civicrm/contribute/campaign',
353ffa53
TO
323 "action=add&reset=1&pageId={$defaults['entity_id']}&component=event",
324 FALSE, NULL, TRUE,
325 TRUE);
481a74f4
TO
326 $this->assign('linkTextUrl', $linkTextUrl);
327 $this->assign('linkText', $linkText);
08ffe40c 328 }
6a488035 329 }
6a488035
TO
330
331 CRM_Utils_System::setTitle($defaults['thankyou_title']);
332 $this->assign('thankYouText', $defaults['thankyou_text']);
333 }
96025800 334
6a488035 335}