Commit | Line | Data |
---|---|---|
6a488035 TO |
1 | <?php |
2 | /* | |
3 | +--------------------------------------------------------------------+ | |
232624b1 | 4 | | CiviCRM version 4.4 | |
6a488035 TO |
5 | +--------------------------------------------------------------------+ |
6 | | Copyright (C) 2011 Marty Wright | | |
7 | | Licensed to CiviCRM under the Academic Free License version 3.0. | | |
8 | +--------------------------------------------------------------------+ | |
9 | | This file is a part of CiviCRM. | | |
10 | | | | |
11 | | CiviCRM is free software; you can copy, modify, and distribute it | | |
12 | | under the terms of the GNU Affero General Public License | | |
13 | | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. | | |
14 | | | | |
15 | | CiviCRM is distributed in the hope that it will be useful, but | | |
16 | | WITHOUT ANY WARRANTY; without even the implied warranty of | | |
17 | | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | | |
18 | | See the GNU Affero General Public License for more details. | | |
19 | | | | |
20 | | You should have received a copy of the GNU Affero General Public | | |
21 | | License and the CiviCRM Licensing Exception along | | |
22 | | with this program; if not, contact CiviCRM LLC | | |
23 | | at info[AT]civicrm[DOT]org. If you have questions about the | | |
24 | | GNU Affero General Public License or the licensing of CiviCRM, | | |
25 | | see the CiviCRM license FAQ at http://civicrm.org/licensing | | |
26 | +--------------------------------------------------------------------+ | |
27 | */ | |
28 | ||
29 | /** | |
30 | * | |
31 | * @package CRM | |
32 | * @copyright CiviCRM LLC (c) 2004-2013 | |
33 | * $Id$ | |
34 | * | |
35 | */ | |
36 | ||
37 | /** | |
38 | * This class generates form components for Scheduling Reminders | |
39 | * | |
40 | */ | |
41 | class CRM_Admin_Form_ScheduleReminders extends CRM_Admin_Form { | |
42 | ||
43 | /** | |
44 | * Scheduled Reminder ID | |
45 | */ | |
46 | protected $_id = NULL; | |
47 | ||
48 | public $_freqUnits; | |
49 | ||
50 | /** | |
51 | * Function to build the form | |
52 | * | |
355ba699 | 53 | * @return void |
6a488035 TO |
54 | * @access public |
55 | */ | |
56 | public function buildQuickForm() { | |
57 | parent::buildQuickForm(); | |
58 | $this->_mappingID = $mappingID = NULL; | |
a3e3eea1 | 59 | $providersCount = CRM_SMS_BAO_Provider::activeProviderCount(); |
6a488035 TO |
60 | |
61 | if ($this->_action & (CRM_Core_Action::DELETE)) { | |
62 | $reminderName = | |
63 | CRM_Core_DAO::getFieldValue('CRM_Core_DAO_ActionSchedule', $this->_id, 'title'); | |
64 | $this->_context = CRM_Utils_Request::retrieve('context', 'String', $this); | |
65 | if ($this->_context == 'event') { | |
66 | $this->_eventId = CRM_Utils_Request::retrieve('eventId', 'Integer', $this); | |
67 | } | |
68 | $this->assign('reminderName', $reminderName); | |
69 | return; | |
70 | } | |
71 | elseif ($this->_action & (CRM_Core_Action::UPDATE)) { | |
72 | $this->_mappingID = | |
73 | CRM_Core_DAO::getFieldValue('CRM_Core_DAO_ActionSchedule', $this->_id, 'mapping_id'); | |
74 | $this->_context = CRM_Utils_Request::retrieve('context', 'String', $this); | |
75 | if ($this->_context == 'event') { | |
76 | $this->_eventId = CRM_Utils_Request::retrieve('eventId', 'Integer', $this); | |
77 | } | |
78 | } | |
79 | ||
8cc574cf | 80 | if (!empty($_POST) && !empty($_POST['entity'])) { |
6a488035 TO |
81 | $mappingID = $_POST['entity'][0]; |
82 | } | |
83 | elseif ($this->_mappingID) { | |
84 | $mappingID = $this->_mappingID; | |
85 | } | |
86 | ||
87 | $this->add( | |
88 | 'text', | |
89 | 'title', | |
90 | ts('Title'), | |
91 | array('size' => 45, 'maxlength' => 128), | |
92 | TRUE | |
93 | ); | |
94 | ||
95 | $selectionOptions = CRM_Core_BAO_ActionSchedule::getSelection($mappingID); | |
96 | extract($selectionOptions); | |
97 | ||
98 | if (empty($sel1)) { | |
99 | CRM_Core_Error::fatal('Could not find mapping for scheduled reminders.'); | |
100 | } | |
101 | $this->assign('entityMapping', json_encode($entityMapping)); | |
102 | $this->assign('recipientMapping', json_encode($recipientMapping)); | |
103 | ||
3e315abc | 104 | $sel = & $this->add( |
6a488035 TO |
105 | 'hierselect', |
106 | 'entity', | |
107 | ts('Entity'), | |
108 | array( | |
109 | 'name' => 'entity[0]', | |
110 | 'style' => 'vertical-align: top;', | |
111 | ), | |
112 | TRUE | |
113 | ); | |
114 | $sel->setOptions(array($sel1, $sel2, $sel3)); | |
115 | ||
116 | if (is_a($sel->_elements[1], 'HTML_QuickForm_select')) { | |
117 | // make second selector a multi-select - | |
118 | $sel->_elements[1]->setMultiple(TRUE); | |
119 | $sel->_elements[1]->setSize(5); | |
120 | } | |
121 | ||
122 | if (is_a($sel->_elements[2], 'HTML_QuickForm_select')) { | |
123 | // make third selector a multi-select - | |
124 | $sel->_elements[2]->setMultiple(TRUE); | |
125 | $sel->_elements[2]->setSize(5); | |
126 | } | |
127 | ||
128 | //get the frequency units. | |
129 | $this->_freqUnits = array('hour' => 'hour') + CRM_Core_OptionGroup::values('recur_frequency_units'); | |
130 | ||
131 | //pass the mapping ID in UPDATE mode | |
132 | $mappings = CRM_Core_BAO_ActionSchedule::getMapping($mappingID); | |
133 | ||
134 | $numericOptions = CRM_Core_SelectValues::getNumericOptions(0, 30); | |
135 | ||
136 | //reminder_interval | |
137 | $this->add('select', 'start_action_offset', ts('When'), $numericOptions); | |
a3e3eea1 | 138 | $title = ts('Email'); |
139 | $isActive = ts('Send email'); | |
140 | $recordActivity = ts('Record activity for automated email'); | |
141 | if ($providersCount) { | |
142 | $title = ts('Email or SMS'); | |
143 | $isActive = ts('Send email or SMS'); | |
144 | $recordActivity = ts('Record activity for automated email or SMS'); | |
145 | $options = CRM_Core_OptionGroup::values('msg_mode'); | |
146 | $this->add('select', 'mode', ts('Send as'), $options); | |
147 | ||
148 | $providers = CRM_SMS_BAO_Provider::getProviders(NULL, NULL, TRUE, 'is_default desc'); | |
149 | ||
150 | $providerSelect = array(); | |
151 | foreach ($providers as $provider) { | |
152 | $providerSelect[$provider['id']] = $provider['title']; | |
153 | } | |
154 | $this->add('select', 'sms_provider_id', ts('From'), $providerSelect, TRUE); | |
155 | } | |
6a488035 | 156 | |
a3e3eea1 | 157 | $this->assign('title', $title); |
6a488035 TO |
158 | foreach ($this->_freqUnits as $val => $label) { |
159 | $freqUnitsDisplay[$val] = ts('%1(s)', array(1 => $label)); | |
160 | } | |
161 | ||
162 | $this->addDate('absolute_date', ts('Start Date'), FALSE, array('formatType' => 'mailing')); | |
163 | ||
164 | //reminder_frequency | |
165 | $this->add('select', 'start_action_unit', ts('Frequency'), $freqUnitsDisplay, TRUE); | |
166 | ||
167 | $condition = array('before' => ts('before'), | |
168 | 'after' => ts('after'), | |
169 | ); | |
170 | //reminder_action | |
171 | $this->add('select', 'start_action_condition', ts('Action Condition'), $condition); | |
172 | ||
173 | $this->add('select', 'start_action_date', ts('Date Field'), $sel4, TRUE); | |
174 | ||
a3e3eea1 | 175 | $this->addElement('checkbox', 'record_activity', $recordActivity); |
6a488035 TO |
176 | |
177 | $this->addElement('checkbox', 'is_repeat', ts('Repeat'), | |
178 | NULL, array('onclick' => "return showHideByValue('is_repeat',true,'repeatFields','table-row','radio',false);") | |
179 | ); | |
180 | ||
181 | $this->add('select', 'repetition_frequency_unit', ts('every'), $freqUnitsDisplay); | |
182 | $this->add('select', 'repetition_frequency_interval', ts('every'), $numericOptions); | |
183 | $this->add('select', 'end_frequency_unit', ts('until'), $freqUnitsDisplay); | |
184 | $this->add('select', 'end_frequency_interval', ts('until'), $numericOptions); | |
185 | $this->add('select', 'end_action', ts('Repetition Condition'), $condition, TRUE); | |
186 | $this->add('select', 'end_date', ts('Date Field'), $sel4, TRUE); | |
187 | ||
188 | $recipient = 'activity_contacts'; | |
189 | $recipientListingOptions = array(); | |
190 | ||
191 | if ($mappingID) { | |
192 | $recipient = CRM_Core_DAO::getFieldValue('CRM_Core_DAO_ActionMapping', | |
193 | $mappingID, | |
194 | 'entity_recipient' | |
195 | ); | |
196 | } | |
197 | ||
3e315abc | 198 | $limitOptions = array(1 => ts('Limit to'), 0 => ts('Addition to')); |
199 | $this->add('select', 'limit_to', ts('Limit Options'), $limitOptions); | |
8ef12e64 | 200 | |
3e315abc | 201 | $this->add('select', 'recipient', ts('Recipients'), $sel5[$recipient], |
6a488035 TO |
202 | FALSE, array('onClick' => "showHideByValue('recipient','manual','recipientManual','table-row','select',false); showHideByValue('recipient','group','recipientGroup','table-row','select',false);") |
203 | ); | |
204 | ||
a7488080 | 205 | if (!empty($_POST['is_recipient_listing'])) { |
6a488035 TO |
206 | $recipientListingOptions = CRM_Core_BAO_ActionSchedule::getRecipientListing($_POST['entity'][0], $_POST['recipient']); |
207 | } | |
a7488080 | 208 | elseif (!empty($this->_values['recipient_listing'])) { |
6a488035 TO |
209 | $recipientListingOptions = CRM_Core_BAO_ActionSchedule::getRecipientListing($this->_values['mapping_id'], $this->_values['recipient']); |
210 | } | |
211 | $recipientListing = $this->add('select', 'recipient_listing', ts('Recipient Listing'), $recipientListingOptions); | |
212 | $recipientListing->setMultiple(TRUE); | |
213 | $this->add('hidden', 'is_recipient_listing', empty($recipientListingOptions) ? FALSE : TRUE, array('id' => 'is_recipient_listing')); | |
214 | ||
3e315abc | 215 | //token input url |
6a488035 TO |
216 | $tokenUrl = CRM_Utils_System::url('civicrm/ajax/checkemail', |
217 | 'noemail=1', | |
218 | FALSE, NULL, FALSE | |
219 | ); | |
220 | $this->assign('tokenUrl', $tokenUrl); | |
221 | $this->add('text', 'recipient_manual_id', ts('Manual Recipients')); | |
222 | ||
f10c69fa DL |
223 | $this->addElement( |
224 | 'select', | |
225 | 'group_id', | |
226 | ts('Group'), | |
227 | // CRM-13577 | |
228 | CRM_Core_PseudoConstant::group() | |
6a488035 TO |
229 | ); |
230 | ||
231 | CRM_Mailing_BAO_Mailing::commonCompose($this); | |
232 | ||
233 | $this->add('text', 'subject', ts('Subject'), | |
234 | CRM_Core_DAO::getAttribute('CRM_Core_DAO_ActionSchedule', 'subject') | |
235 | ); | |
236 | ||
a3e3eea1 | 237 | $this->add('checkbox', 'is_active', $isActive); |
6a488035 TO |
238 | |
239 | $this->addFormRule(array('CRM_Admin_Form_ScheduleReminders', 'formRule')); | |
240 | } | |
241 | /** | |
242 | * global form rule | |
243 | * | |
244 | * @param array $fields the input form values | |
245 | * | |
246 | * @return true if no errors, else array of errors | |
247 | * @access public | |
248 | * @static | |
249 | */ | |
250 | static function formRule($fields) { | |
251 | $errors = array(); | |
252 | if ((array_key_exists(1, $fields['entity']) && $fields['entity'][1][0] == 0) || | |
253 | (array_key_exists(2, $fields['entity']) && $fields['entity'][2][0] == 0) | |
254 | ) { | |
255 | $errors['entity'] = ts('Please select appropriate value'); | |
256 | } | |
257 | ||
a7488080 | 258 | if (!empty($fields['is_active']) && |
6a488035 TO |
259 | CRM_Utils_System::isNull($fields['subject']) |
260 | ) { | |
261 | $errors['subject'] = ts('Subject is a required field.'); | |
262 | } | |
263 | ||
264 | if (CRM_Utils_System::isNull(CRM_Utils_Array::value(1, $fields['entity']))) { | |
265 | $errors['entity'] = ts('Please select entity value'); | |
266 | } | |
267 | ||
268 | if (!CRM_Utils_System::isNull($fields['absolute_date'])) { | |
2ea4f315 | 269 | if (CRM_Utils_Date::format(CRM_Utils_Date::processDate($fields['absolute_date'], NULL)) < CRM_Utils_Date::format(date('Ymd'))) { |
6a488035 TO |
270 | $errors['absolute_date'] = ts('Absolute date cannot be earlier than the current time.'); |
271 | } | |
272 | } | |
273 | ||
274 | if (!empty($errors)) { | |
275 | return $errors; | |
276 | } | |
277 | ||
278 | return empty($errors) ? TRUE : $errors; | |
279 | } | |
280 | ||
281 | function setDefaultValues() { | |
282 | if ($this->_action & CRM_Core_Action::ADD) { | |
283 | $defaults['is_active'] = 1; | |
a3e3eea1 | 284 | $defaults['mode'] = 'Email'; |
6a488035 TO |
285 | $defaults['record_activity'] = 1; |
286 | } | |
287 | else { | |
288 | $defaults = $this->_values; | |
289 | $entityValue = explode(CRM_Core_DAO::VALUE_SEPARATOR, | |
290 | CRM_Utils_Array::value('entity_value', $defaults) | |
291 | ); | |
292 | $entityStatus = explode(CRM_Core_DAO::VALUE_SEPARATOR, | |
293 | CRM_Utils_Array::value('entity_status', $defaults) | |
294 | ); | |
295 | $defaults['entity'][0] = CRM_Utils_Array::value('mapping_id', $defaults); | |
296 | $defaults['entity'][1] = $entityValue; | |
297 | $defaults['entity'][2] = $entityStatus; | |
298 | if ($absoluteDate = CRM_Utils_Array::value('absolute_date', $defaults)) { | |
299 | list($date, $time) = CRM_Utils_Date::setDateDefaults($absoluteDate); | |
300 | $defaults['absolute_date'] = $date; | |
301 | } | |
302 | ||
303 | if ($recipientListing = CRM_Utils_Array::value('recipient_listing', $defaults)) { | |
304 | $defaults['recipient_listing'] = explode(CRM_Core_DAO::VALUE_SEPARATOR, | |
305 | $recipientListing | |
306 | ); | |
307 | } | |
308 | $defaults['text_message'] = CRM_Utils_Array::value('body_text', $defaults); | |
309 | $defaults['html_message'] = CRM_Utils_Array::value('body_html', $defaults); | |
310 | $defaults['template'] = CRM_Utils_Array::value('msg_template_id', $defaults); | |
a7488080 | 311 | if (!empty($defaults['group_id'])) { |
6a488035 TO |
312 | $defaults['recipient'] = 'group'; |
313 | } | |
a7488080 | 314 | elseif (!empty($defaults['recipient_manual'])) { |
6a488035 TO |
315 | $defaults['recipient'] = 'manual'; |
316 | $recipients = array(); | |
317 | foreach (explode(',', $defaults['recipient_manual']) as $cid) { | |
318 | $recipients[$cid] = CRM_Core_DAO::getFieldValue('CRM_Contact_DAO_Contact', | |
319 | $cid, | |
320 | 'sort_name' | |
321 | ); | |
322 | } | |
323 | $this->assign('recipients', $recipients); | |
324 | } | |
325 | } | |
326 | ||
327 | return $defaults; | |
328 | } | |
329 | ||
330 | /** | |
331 | * Function to process the form | |
332 | * | |
333 | * @access public | |
334 | * | |
355ba699 | 335 | * @return void |
6a488035 TO |
336 | */ |
337 | public function postProcess() { | |
338 | if ($this->_action & CRM_Core_Action::DELETE) { | |
339 | // delete reminder | |
340 | CRM_Core_BAO_ActionSchedule::del($this->_id); | |
341 | CRM_Core_Session::setStatus(ts('Selected Reminder has been deleted.'), ts('Record Deleted'), 'success'); | |
342 | if ($this->_context == 'event' && $this->_eventId) { | |
343 | $url = CRM_Utils_System::url('civicrm/event/manage/reminder', | |
344 | "reset=1&action=update&id={$this->_eventId}" | |
345 | ); | |
346 | $session = CRM_Core_Session::singleton(); | |
347 | $session->pushUserContext($url); | |
348 | } | |
349 | return; | |
350 | } | |
351 | $values = $this->controller->exportValues($this->getName()); | |
352 | ||
353 | $keys = array( | |
354 | 'title', | |
355 | 'subject', | |
356 | 'absolute_date', | |
357 | 'group_id', | |
3e315abc | 358 | 'record_activity', |
a3e3eea1 | 359 | 'limit_to', |
360 | 'mode', | |
361 | 'sms_provider_id' | |
6a488035 TO |
362 | ); |
363 | foreach ($keys as $key) { | |
364 | $params[$key] = CRM_Utils_Array::value($key, $values); | |
365 | } | |
366 | ||
367 | $moreKeys = array( | |
3e315abc | 368 | 'start_action_offset', |
369 | 'start_action_unit', | |
370 | 'start_action_condition', | |
371 | 'start_action_date', | |
6a488035 TO |
372 | 'repetition_frequency_unit', |
373 | 'repetition_frequency_interval', | |
374 | 'end_frequency_unit', | |
375 | 'end_frequency_interval', | |
3e315abc | 376 | 'end_action', |
377 | 'end_date', | |
6a488035 TO |
378 | ); |
379 | ||
380 | if ($absoluteDate = CRM_Utils_Array::value('absolute_date', $params)) { | |
381 | $params['absolute_date'] = CRM_Utils_Date::processDate($absoluteDate); | |
382 | foreach ($moreKeys as $mkey) { | |
383 | $params[$mkey] = 'null'; | |
384 | } | |
385 | } | |
386 | else { | |
387 | $params['absolute_date'] = 'null'; | |
388 | foreach ($moreKeys as $mkey) { | |
389 | $params[$mkey] = CRM_Utils_Array::value($mkey, $values); | |
390 | } | |
391 | } | |
392 | ||
393 | $params['body_text'] = CRM_Utils_Array::value('text_message', $values); | |
394 | $params['body_html'] = CRM_Utils_Array::value('html_message', $values); | |
395 | ||
396 | if (CRM_Utils_Array::value('recipient', $values) == 'manual') { | |
397 | $params['recipient_manual'] = CRM_Utils_Array::value('recipient_manual_id', $values); | |
398 | $params['group_id'] = $params['recipient'] = $params['recipient_listing'] = 'null'; | |
399 | } | |
400 | elseif (CRM_Utils_Array::value('recipient', $values) == 'group') { | |
401 | $params['group_id'] = $values['group_id']; | |
402 | $params['recipient_manual'] = $params['recipient'] = $params['recipient_listing'] = 'null'; | |
403 | } | |
404 | elseif (!CRM_Utils_System::isNull($values['recipient_listing'])) { | |
405 | $params['recipient'] = CRM_Utils_Array::value('recipient', $values); | |
406 | $params['recipient_listing'] = implode(CRM_Core_DAO::VALUE_SEPARATOR, | |
407 | CRM_Utils_Array::value('recipient_listing', $values) | |
408 | ); | |
409 | $params['group_id'] = $params['recipient_manual'] = 'null'; | |
410 | } | |
411 | else { | |
412 | $params['recipient'] = CRM_Utils_Array::value('recipient', $values); | |
413 | $params['group_id'] = $params['recipient_manual'] = $params['recipient_listing'] = 'null'; | |
414 | } | |
415 | ||
416 | $params['mapping_id'] = $values['entity'][0]; | |
417 | $entity_value = $values['entity'][1]; | |
418 | $entity_status = $values['entity'][2]; | |
419 | ||
420 | foreach (array( | |
421 | 'entity_value', 'entity_status') as $key) { | |
422 | $params[$key] = implode(CRM_Core_DAO::VALUE_SEPARATOR, $$key); | |
423 | } | |
424 | ||
425 | $params['is_active'] = CRM_Utils_Array::value('is_active', $values, 0); | |
426 | $params['is_repeat'] = CRM_Utils_Array::value('is_repeat', $values, 0); | |
427 | ||
428 | if (CRM_Utils_Array::value('is_repeat', $values) == 0) { | |
429 | $params['repetition_frequency_unit'] = 'null'; | |
430 | $params['repetition_frequency_interval'] = 'null'; | |
431 | $params['end_frequency_unit'] = 'null'; | |
432 | $params['end_frequency_interval'] = 'null'; | |
433 | $params['end_action'] = 'null'; | |
434 | $params['end_date'] = 'null'; | |
435 | } | |
436 | ||
437 | if ($this->_action & CRM_Core_Action::UPDATE) { | |
438 | $params['id'] = $this->_id; | |
439 | } | |
440 | elseif ($this->_action & CRM_Core_Action::ADD) { | |
441 | // we do this only once, so name never changes | |
442 | $params['name'] = CRM_Utils_String::munge($params['title'], '_', 64); | |
443 | } | |
444 | ||
445 | $composeFields = array( | |
446 | 'template', 'saveTemplate', | |
447 | 'updateTemplate', 'saveTemplateName', | |
448 | ); | |
449 | $msgTemplate = NULL; | |
450 | //mail template is composed | |
451 | ||
452 | $composeParams = array(); | |
453 | foreach ($composeFields as $key) { | |
a7488080 | 454 | if (!empty($values[$key])) { |
6a488035 TO |
455 | $composeParams[$key] = $values[$key]; |
456 | } | |
457 | } | |
458 | ||
a7488080 | 459 | if (!empty($composeParams['updateTemplate'])) { |
6a488035 TO |
460 | $templateParams = array( |
461 | 'msg_text' => $params['body_text'], | |
462 | 'msg_html' => $params['body_html'], | |
463 | 'msg_subject' => $params['subject'], | |
464 | 'is_active' => TRUE, | |
465 | ); | |
466 | ||
467 | $templateParams['id'] = $values['template']; | |
468 | ||
c6327d7d | 469 | $msgTemplate = CRM_Core_BAO_MessageTemplate::add($templateParams); |
6a488035 TO |
470 | } |
471 | ||
a7488080 | 472 | if (!empty($composeParams['saveTemplate'])) { |
6a488035 TO |
473 | $templateParams = array( |
474 | 'msg_text' => $params['body_text'], | |
475 | 'msg_html' => $params['body_html'], | |
476 | 'msg_subject' => $params['subject'], | |
477 | 'is_active' => TRUE, | |
478 | ); | |
479 | ||
480 | $templateParams['msg_title'] = $composeParams['saveTemplateName']; | |
481 | ||
c6327d7d | 482 | $msgTemplate = CRM_Core_BAO_MessageTemplate::add($templateParams); |
6a488035 TO |
483 | } |
484 | ||
485 | if (isset($msgTemplate->id)) { | |
486 | $params['msg_template_id'] = $msgTemplate->id; | |
487 | } | |
488 | else { | |
489 | $params['msg_template_id'] = CRM_Utils_Array::value('template', $values); | |
490 | } | |
491 | ||
24f14405 E |
492 | $bao = CRM_Core_BAO_ActionSchedule::add($params); |
493 | // we need to set this on the form so that hooks can identify the created entity | |
494 | $this->set('id', $bao->id); | |
495 | $bao->free(); | |
6a488035 TO |
496 | |
497 | $status = ts("Your new Reminder titled %1 has been saved.", | |
498 | array(1 => "<strong>{$values['title']}</strong>") | |
499 | ); | |
500 | if ($this->_action & CRM_Core_Action::UPDATE) { | |
501 | $status = ts("Your Reminder titled %1 has been updated.", | |
502 | array(1 => "<strong>{$values['title']}</strong>") | |
503 | ); | |
504 | ||
505 | if ($this->_context == 'event' && $this->_eventId) { | |
506 | $url = CRM_Utils_System::url('civicrm/event/manage/reminder', | |
507 | "reset=1&action=update&id={$this->_eventId}" | |
508 | ); | |
509 | $session = CRM_Core_Session::singleton(); | |
510 | $session->pushUserContext($url); | |
511 | } | |
512 | } | |
513 | CRM_Core_Session::setStatus($status, ts('Saved'), 'success'); | |
514 | } | |
515 | } | |
516 |