Merge pull request #9592 from kainukempowerment/CRM-19803
[civicrm-core.git] / CRM / Event / Form / ManageEvent / Fee.php
1 <?php
2 /*
3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.7 |
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2017 |
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 * @package CRM
30 * @copyright CiviCRM LLC (c) 2004-2017
31 */
32
33 /**
34 * This class generates form components for Event Fees.
35 */
36 class CRM_Event_Form_ManageEvent_Fee extends CRM_Event_Form_ManageEvent {
37
38 /**
39 * Constants for number of options for data types of multiple option.
40 */
41 const NUM_OPTION = 11;
42
43 /**
44 * Constants for number of discounts for the event.
45 */
46 const NUM_DISCOUNT = 6;
47
48 /**
49 * Page action.
50 */
51 public $_action;
52
53 /**
54 * In Date.
55 */
56 private $_inDate;
57
58 /**
59 * Set variables up before form is built.
60 */
61 public function preProcess() {
62 parent::preProcess();
63 }
64
65 /**
66 * Set default values for the form.
67 *
68 * For edit/view mode the default values are retrieved from the database.
69 */
70 public function setDefaultValues() {
71 $parentDefaults = parent::setDefaultValues();
72
73 $eventId = $this->_id;
74 $params = array();
75 $defaults = array();
76 if (isset($eventId)) {
77 $params = array('id' => $eventId);
78 }
79
80 CRM_Event_BAO_Event::retrieve($params, $defaults);
81
82 if (isset($eventId)) {
83 $price_set_id = CRM_Price_BAO_PriceSet::getFor('civicrm_event', $eventId, NULL, 1);
84
85 if ($price_set_id) {
86 $defaults['price_set_id'] = $price_set_id;
87 }
88 else {
89 $priceSetId = CRM_Price_BAO_PriceSet::getFor('civicrm_event', $eventId, NULL);
90 if ($priceSetId) {
91 if ($isQuick = CRM_Core_DAO::getFieldValue('CRM_Price_DAO_PriceSet', $priceSetId, 'is_quick_config')) {
92 $this->assign('isQuick', $isQuick);
93 $priceField = CRM_Core_DAO::getFieldValue('CRM_Price_DAO_PriceField', $priceSetId, 'id', 'price_set_id');
94 $options = array();
95 $priceFieldOptions = CRM_Price_BAO_PriceFieldValue::getValues($priceField, $options, 'weight', TRUE);
96 $defaults['price_field_id'] = $priceField;
97 $countRow = 0;
98 foreach ($options as $optionId => $optionValue) {
99 $countRow++;
100 $defaults['value'][$countRow] = CRM_Utils_Money::format($optionValue['amount'], NULL, '%a');
101 $defaults['label'][$countRow] = $optionValue['label'];
102 $defaults['name'][$countRow] = $optionValue['name'];
103 $defaults['weight'][$countRow] = $optionValue['weight'];
104 $defaults['price_field_value'][$countRow] = $optionValue['id'];
105 if ($optionValue['is_default']) {
106 $defaults['default'] = $countRow;
107 }
108 }
109 }
110 }
111 }
112 }
113
114 //check if discounted
115 $discountedEvent = CRM_Core_BAO_Discount::getOptionGroup($this->_id, 'civicrm_event');
116 if (!empty($discountedEvent)) {
117 $defaults['is_discount'] = $i = 1;
118 $totalLables = $maxSize = $defaultDiscounts = array();
119 foreach ($discountedEvent as $optionGroupId) {
120 $defaults['discount_price_set'][] = $optionGroupId;
121 $name = $defaults["discount_name[$i]"] = CRM_Core_DAO::getFieldValue('CRM_Price_DAO_PriceSet', $optionGroupId, 'title');
122
123 list($defaults["discount_start_date[$i]"]) = CRM_Utils_Date::setDateDefaults(CRM_Core_DAO::getFieldValue('CRM_Core_DAO_Discount', $optionGroupId,
124 'start_date', 'price_set_id'
125 ));
126 list($defaults["discount_end_date[$i]"]) = CRM_Utils_Date::setDateDefaults(CRM_Core_DAO::getFieldValue('CRM_Core_DAO_Discount', $optionGroupId,
127 'end_date', 'price_set_id'
128 ));
129 $defaultDiscounts[] = CRM_Price_BAO_PriceSet::getSetDetail($optionGroupId);
130 $i++;
131 }
132
133 //avoid moving up value of lable when some labels don't
134 //have a value ,fixed for CRM-3088
135 $rowCount = 1;
136 foreach ($defaultDiscounts as $val) {
137 $discountFields = current($val);
138 $discountFields = current($discountFields['fields']);
139
140 foreach ($discountFields['options'] as $discountFieldsval) {
141 $defaults['discounted_label'][$discountFieldsval['weight']] = $discountFieldsval['label'];
142 $defaults['discounted_value'][$discountFieldsval['weight']][$rowCount] = CRM_Utils_Money::format($discountFieldsval['amount'], NULL, '%a');
143 $defaults['discount_option_id'][$rowCount][$discountFieldsval['weight']] = $discountFieldsval['id'];
144 if (!empty($discountFieldsval['is_default'])) {
145 $defaults['discounted_default'] = $discountFieldsval['weight'];
146 }
147 }
148 $rowCount++;
149 }
150 //CRM-12970
151 ksort($defaults['discounted_value']);
152 ksort($defaults['discounted_label']);
153 $rowCount = 1;
154 foreach ($defaults['discounted_label'] as $key => $value) {
155 if ($key != $rowCount) {
156 $defaults['discounted_label'][$rowCount] = $value;
157 $defaults['discounted_value'][$rowCount] = $defaults['discounted_value'][$key];
158 unset($defaults['discounted_value'][$key]);
159 unset($defaults['discounted_label'][$key]);
160 foreach ($defaults['discount_option_id'] as &$optionIds) {
161 if (array_key_exists($key, $optionIds)) {
162 $optionIds[$rowCount] = $optionIds[$key];
163 unset($optionIds[$key]);
164 }
165 }
166 }
167 $rowCount++;
168 }
169
170 $this->set('discountSection', 1);
171 $this->buildQuickForm();
172 }
173 elseif (!empty($defaults['label'])) {
174 //if Regular Fees are present in DB and event fee page is in update mode
175 $defaults['discounted_label'] = $defaults['label'];
176 }
177 elseif (!empty($this->_submitValues['label'])) {
178 //if event is newly created, use submitted values for
179 //discount labels
180 if (is_array($this->_submitValues['label'])) {
181 $k = 1;
182 foreach ($this->_submitValues['label'] as $value) {
183 if ($value) {
184 $defaults['discounted_label'][$k] = $value;
185 $k++;
186 }
187 }
188 }
189 }
190 $defaults['id'] = $eventId;
191 if (!empty($totalLables)) {
192 $maxKey = count($totalLables) - 1;
193 if (isset($maxKey) && !empty($totalLables[$maxKey]['value'])) {
194 foreach ($totalLables[$maxKey]['value'] as $i => $v) {
195 if ($totalLables[$maxKey]['amount_id'][$i] == CRM_Utils_Array::value('default_discount_fee_id', $defaults)) {
196 $defaults['discounted_default'] = $i;
197 break;
198 }
199 }
200 }
201 }
202
203 if (!isset($defaults['discounted_default'])) {
204 $defaults['discounted_default'] = 1;
205 }
206
207 if (!isset($defaults['is_monetary'])) {
208 $defaults['is_monetary'] = 1;
209 }
210
211 if (!isset($defaults['fee_label'])) {
212 $defaults['fee_label'] = ts('Event Fee(s)');
213 }
214
215 if (!isset($defaults['pay_later_text']) ||
216 empty($defaults['pay_later_text'])
217 ) {
218 $defaults['pay_later_text'] = ts('I will send payment by check');
219 }
220
221 $this->_showHide = new CRM_Core_ShowHideBlocks();
222 if (!$defaults['is_monetary']) {
223 $this->_showHide->addHide('event-fees');
224 }
225
226 if (isset($defaults['price_set_id'])) {
227 $this->_showHide->addHide('map-field');
228 }
229 $this->_showHide->addToTemplate();
230 $this->assign('inDate', $this->_inDate);
231
232 if (!empty($defaults['payment_processor'])) {
233 $defaults['payment_processor'] = str_replace(CRM_Core_DAO::VALUE_SEPARATOR, ',',
234 $defaults['payment_processor']
235 );
236 }
237 return $defaults;
238 }
239
240 /**
241 * Build the form object.
242 */
243 public function buildQuickForm() {
244
245 $this->addYesNo('is_monetary',
246 ts('Paid Event'),
247 NULL,
248 NULL,
249 array('onclick' => "return showHideByValue('is_monetary','0','event-fees','block','radio',false);")
250 );
251
252 //add currency element.
253 $this->addCurrency('currency', ts('Currency'), FALSE);
254
255 $paymentProcessor = CRM_Core_PseudoConstant::paymentProcessor();
256
257 $this->assign('paymentProcessor', $paymentProcessor);
258
259 $this->addEntityRef('payment_processor', ts('Payment Processor'), array(
260 'entity' => 'PaymentProcessor',
261 'multiple' => TRUE,
262 'api' => array(
263 'params' => array('domain_id' => CRM_Core_Config::domainID()),
264 ),
265 'select' => array('minimumInputLength' => 0),
266 ));
267
268 // financial type
269 if (!CRM_Financial_BAO_FinancialType::isACLFinancialTypeStatus() ||
270 (CRM_Financial_BAO_FinancialType::isACLFinancialTypeStatus() && CRM_Core_Permission::check('administer CiviCRM Financial Types'))) {
271 $this->addSelect('financial_type_id');
272 }
273 else {
274 CRM_Financial_BAO_FinancialType::getAvailableFinancialTypes($financialTypes, CRM_Core_Action::ADD);
275 $this->addSelect('financial_type_id', array('context' => 'search', 'options' => $financialTypes));
276 }
277 // add pay later options
278 $this->addElement('checkbox', 'is_pay_later', ts('Enable Pay Later option?'), NULL,
279 array('onclick' => "return showHideByValue('is_pay_later','','payLaterOptions','block','radio',false);")
280 );
281 $this->addElement('textarea', 'pay_later_text', ts('Pay Later Label'),
282 CRM_Core_DAO::getAttribute('CRM_Event_DAO_Event', 'pay_later_text'),
283 FALSE
284 );
285 $this->add('wysiwyg', 'pay_later_receipt', ts('Pay Later Instructions'), CRM_Core_DAO::getAttribute('CRM_Event_DAO_Event', 'pay_later_receipt'));
286
287 $this->addElement('checkbox', 'is_billing_required', ts('Billing address required'));
288 $this->add('text', 'fee_label', ts('Fee Label'));
289
290 $price = CRM_Price_BAO_PriceSet::getAssoc(FALSE, 'CiviEvent');
291 if (CRM_Utils_System::isNull($price)) {
292 $this->assign('price', FALSE);
293 }
294 else {
295 $this->assign('price', TRUE);
296 }
297 $this->add('select', 'price_set_id', ts('Price Set'),
298 array(
299 '' => ts('- none -'),
300 ) + $price,
301 NULL, array('onchange' => "return showHideByValue('price_set_id', '', 'map-field', 'block', 'select', false);")
302 );
303 $default = array($this->createElement('radio', NULL, NULL, NULL, 0));
304 $this->add('hidden', 'price_field_id', '', array('id' => 'price_field_id'));
305 for ($i = 1; $i <= self::NUM_OPTION; $i++) {
306 // label
307 $this->add('text', "label[$i]", ts('Label'), CRM_Core_DAO::getAttribute('CRM_Core_DAO_OptionValue', 'label'));
308 $this->add('hidden', "price_field_value[$i]", '', array('id' => "price_field_value[$i]"));
309
310 // value
311 $this->add('text', "value[$i]", ts('Value'), CRM_Core_DAO::getAttribute('CRM_Core_DAO_OptionValue', 'value'));
312 $this->addRule("value[$i]", ts('Please enter a valid money value for this field (e.g. %1).', array(1 => CRM_Utils_Money::format('99.99', ' '))), 'money');
313
314 // default
315 $default[] = $this->createElement('radio', NULL, NULL, NULL, $i);
316 }
317
318 $this->addGroup($default, 'default');
319
320 $this->addElement('checkbox', 'is_discount', ts('Discounts by Signup Date?'), NULL,
321 array('onclick' => "warnDiscountDel(); return showHideByValue('is_discount','','discount','block','radio',false);")
322 );
323 $discountSection = $this->get('discountSection');
324
325 $this->assign('discountSection', $discountSection);
326
327 // form fields of Discount sets
328 $defaultOption = array();
329 $_showHide = new CRM_Core_ShowHideBlocks('', '');
330
331 for ($i = 1; $i <= self::NUM_DISCOUNT; $i++) {
332 //the show hide blocks
333 $showBlocks = 'discount_' . $i;
334 if ($i > 2) {
335 $_showHide->addHide($showBlocks);
336 }
337 else {
338 $_showHide->addShow($showBlocks);
339 }
340
341 //Increment by 1 of start date of previous end date.
342 if (is_array($this->_submitValues) &&
343 !empty($this->_submitValues['discount_name'][$i]) &&
344 !empty($this->_submitValues['discount_name'][$i + 1]) &&
345 isset($this->_submitValues['discount_end_date']) &&
346 isset($this->_submitValues['discount_end_date'][$i]) &&
347 $i < self::NUM_DISCOUNT - 1
348 ) {
349 $end_date = CRM_Utils_Date::processDate($this->_submitValues['discount_end_date'][$i]);
350 if (!empty($this->_submitValues['discount_end_date'][$i + 1])
351 && empty($this->_submitValues['discount_start_date'][$i + 1])
352 ) {
353 list($this->_submitValues['discount_start_date'][$i + 1]) = CRM_Utils_Date::setDateDefaults(date('Y-m-d', strtotime("+1 days $end_date")));
354 }
355 }
356 //Decrement by 1 of end date from next start date.
357 if ($i > 1 &&
358 is_array($this->_submitValues) &&
359 !empty($this->_submitValues['discount_name'][$i]) &&
360 !empty($this->_submitValues['discount_name'][$i - 1]) &&
361 isset($this->_submitValues['discount_start_date']) &&
362 isset($this->_submitValues['discount_start_date'][$i])
363 ) {
364 $start_date = CRM_Utils_Date::processDate($this->_submitValues['discount_start_date'][$i]);
365 if (!empty($this->_submitValues['discount_start_date'][$i])
366 && empty($this->_submitValues['discount_end_date'][$i - 1])
367 ) {
368 list($this->_submitValues['discount_end_date'][$i - 1]) = CRM_Utils_Date::setDateDefaults(date('Y-m-d', strtotime("-1 days $start_date")));
369 }
370 }
371
372 //discount name
373 $this->add('text', 'discount_name[' . $i . ']', ts('Discount Name'),
374 CRM_Core_DAO::getAttribute('CRM_Price_DAO_PriceSet', 'title')
375 );
376
377 $this->add('hidden', "discount_price_set[$i]", '', array('id' => "discount_price_set[$i]"));
378
379 //discount start date
380 $this->addDate('discount_start_date[' . $i . ']', ts('Discount Start Date'), FALSE, array('formatType' => 'activityDate'));
381
382 //discount end date
383 $this->addDate('discount_end_date[' . $i . ']', ts('Discount End Date'), FALSE, array('formatType' => 'activityDate'));
384 }
385 $_showHide->addToTemplate();
386 $this->addElement('submit', $this->getButtonName('submit'), ts('Add Discount Set to Fee Table'),
387 array('class' => 'crm-form-submit cancel')
388 );
389
390 $this->buildAmountLabel();
391 parent::buildQuickForm();
392 }
393
394 /**
395 * Add local and global form rules.
396 */
397 public function addRules() {
398 $this->addFormRule(array('CRM_Event_Form_ManageEvent_Fee', 'formRule'));
399 }
400
401 /**
402 * Global validation rules for the form.
403 *
404 * @param array $values
405 * Posted values of the form.
406 *
407 * @return array
408 * list of errors to be posted back to the form
409 */
410 public static function formRule($values) {
411 $errors = array();
412 if (!empty($values['is_discount'])) {
413 $occurDiscount = array_count_values($values['discount_name']);
414 $countemptyrows = 0;
415 $countemptyvalue = 0;
416 for ($i = 1; $i <= self::NUM_DISCOUNT; $i++) {
417 $start_date = $end_date = NULL;
418 if (!empty($values['discount_name'][$i])) {
419 if (!empty($values['discount_start_date'][$i])) {
420 $start_date = ($values['discount_start_date'][$i]) ? CRM_Utils_Date::processDate($values['discount_start_date'][$i]) : 0;
421 }
422 if (!empty($values['discount_end_date'][$i])) {
423 $end_date = ($values['discount_end_date'][$i]) ? CRM_Utils_Date::processDate($values['discount_end_date'][$i]) : 0;
424 }
425
426 if ($start_date && $end_date && strcmp($end_date, $start_date) < 0) {
427 $errors["discount_end_date[$i]"] = ts('The discount end date cannot be prior to the start date.');
428 }
429
430 if (!$start_date && !$end_date) {
431 $errors["discount_start_date[$i]"] = $errors["discount_end_date[$i]"] = ts('Please specify either start date or end date.');
432 }
433
434 if ($i > 1) {
435 $end_date_1 = ($values['discount_end_date'][$i - 1]) ? CRM_Utils_Date::processDate($values['discount_end_date'][$i - 1]) : 0;
436 if ($start_date && $end_date_1 && strcmp($end_date_1, $start_date) >= 0) {
437 $errors["discount_start_date[$i]"] = ts('Select non-overlapping discount start date.');
438 }
439 elseif (!$start_date && !$end_date_1) {
440 $j = $i - 1;
441 $errors["discount_start_date[$i]"] = $errors["discount_end_date[$j]"] = ts('Select either of the dates.');
442 }
443 }
444
445 foreach ($occurDiscount as $key => $value) {
446 if ($value > 1 && $key <> '') {
447 if ($key == $values['discount_name'][$i]) {
448 $errors['discount_name[' . $i . ']'] = ts('%1 is already used for Discount Name.', array(1 => $key));
449 }
450 }
451 }
452
453 //validation for discount labels and values
454 for ($index = (self::NUM_OPTION); $index > 0; $index--) {
455 $label = TRUE;
456 if (empty($values['discounted_label'][$index]) && !empty($values['discounted_value'][$index][$i])) {
457 $label = FALSE;
458 if (!$label) {
459 $errors["discounted_label[{$index}]"] = ts('Label cannot be empty.');
460 }
461 }
462 if (!empty($values['discounted_label'][$index])) {
463 $duplicateIndex = CRM_Utils_Array::key($values['discounted_label'][$index], $values['discounted_label']);
464
465 if ((!($duplicateIndex === FALSE)) && (!($duplicateIndex == $index))) {
466 $errors["discounted_label[{$index}]"] = ts('Duplicate label value');
467 }
468 }
469 if (empty($values['discounted_label'][$index]) && empty($values['discounted_value'][$index][$i])) {
470 $countemptyrows++;
471 }
472 if (empty($values['discounted_value'][$index][$i])) {
473 $countemptyvalue++;
474 }
475 }
476 if (!empty($values['_qf_Fee_next']) && ($countemptyrows == 11 || $countemptyvalue == 11)) {
477 $errors["discounted_label[1]"] = $errors["discounted_value[1][$i]"] = ts('At least one fee should be entered for your Discount Set. If you do not see the table to enter discount fees, click the "Add Discount Set to Fee Table" button.');
478 }
479 }
480 }
481 }
482 if ($values['is_monetary']) {
483 //check if financial type is selected
484 if (!$values['financial_type_id']) {
485 $errors['financial_type_id'] = ts("Please select financial type.");
486 }
487
488 //check for the event fee label (mandatory)
489 if (!$values['fee_label']) {
490 $errors['fee_label'] = ts('Please enter the fee label for the paid event.');
491 }
492
493 if (empty($values['price_set_id'])) {
494 //check fee label and amount
495 $check = 0;
496 $optionKeys = array();
497 foreach ($values['label'] as $key => $val) {
498 if (trim($val) && trim($values['value'][$key])) {
499 $optionKeys[$key] = $key;
500 $check++;
501 }
502 }
503
504 $default = CRM_Utils_Array::value('default', $values);
505 if ($default && !in_array($default, $optionKeys)) {
506 $errors['default'] = ts('Please select an appropriate option as default.');
507 }
508
509 if (!$check) {
510 if (!$values['label'][1]) {
511 $errors['label[1]'] = ts('Please enter a label for at least one fee level.');
512 }
513 if (!$values['value'][1]) {
514 $errors['value[1]'] = ts('Please enter an amount for at least one fee level.');
515 }
516 }
517 }
518 if (isset($values['is_pay_later'])) {
519 if (empty($values['pay_later_text'])) {
520 $errors['pay_later_text'] = ts('Please enter the Pay Later prompt to be displayed on the Registration form.');
521 }
522 if (empty($values['pay_later_receipt'])) {
523 $errors['pay_later_receipt'] = ts('Please enter the Pay Later instructions to be displayed to your users.');
524 }
525 }
526 }
527 // CRM-16189
528 try {
529 CRM_Financial_BAO_FinancialAccount::validateFinancialType($values['financial_type_id']);
530 }
531 catch (CRM_Core_Exception $e) {
532 $errors['financial_type_id'] = $e->getMessage();
533 }
534 return empty($errors) ? TRUE : $errors;
535 }
536
537 public function buildAmountLabel() {
538 $default = array();
539 for ($i = 1; $i <= self::NUM_OPTION; $i++) {
540 // label
541 $this->add('text', "discounted_label[$i]", ts('Label'), CRM_Core_DAO::getAttribute('CRM_Core_DAO_OptionValue', 'label'));
542 // value
543 for ($j = 1; $j <= self::NUM_DISCOUNT; $j++) {
544 $this->add('text', "discounted_value[$i][$j]", ts('Value'), array('size' => 10));
545 $this->addRule("discounted_value[$i][$j]", ts('Please enter a valid money value for this field (e.g. %1).', array(1 => CRM_Utils_Money::format('99.99', ' '))), 'money');
546 }
547
548 // default
549 $default[] = $this->createElement('radio', NULL, NULL, NULL, $i);
550 }
551
552 $this->addGroup($default, 'discounted_default');
553 }
554
555 /**
556 * Process the form.
557 */
558 public function postProcess() {
559 $eventTitle = '';
560 $params = $this->exportValues();
561
562 $this->set('discountSection', 0);
563
564 if (!empty($_POST['_qf_Fee_submit'])) {
565 $this->buildAmountLabel();
566 $this->set('discountSection', 2);
567 return;
568 }
569
570 if (!empty($params['payment_processor'])) {
571 $params['payment_processor'] = str_replace(',', CRM_Core_DAO::VALUE_SEPARATOR, $params['payment_processor']);
572 }
573 else {
574 $params['payment_processor'] = 'null';
575 }
576
577 $params['is_pay_later'] = CRM_Utils_Array::value('is_pay_later', $params, 0);
578 $params['is_billing_required'] = CRM_Utils_Array::value('is_billing_required', $params, 0);
579
580 if ($this->_id) {
581
582 // delete all the prior label values or discounts in the custom options table
583 // and delete a price set if one exists
584 //@todo note that this removes the reference from existing participants -
585 // even where there is not change - redress?
586 // note that a more tentative form of this is invoked by passing price_set_id as an array
587 // to event.create see CRM-14069
588 // @todo get all of this logic out of form layer (currently partially in BAO/api layer)
589 if (CRM_Price_BAO_PriceSet::removeFrom('civicrm_event', $this->_id)) {
590 CRM_Core_BAO_Discount::del($this->_id, 'civicrm_event');
591 }
592 }
593
594 if ($params['is_monetary']) {
595 if (!empty($params['price_set_id'])) {
596 //@todo this is now being done in the event BAO if passed price_set_id as an array
597 // per notes on that fn - looking at the api converting to an array
598 // so calling via the api may cause this to be done in the api
599 CRM_Price_BAO_PriceSet::addTo('civicrm_event', $this->_id, $params['price_set_id']);
600 if (!empty($params['price_field_id'])) {
601 $priceSetID = CRM_Core_DAO::getFieldValue('CRM_Price_DAO_PriceField', $params['price_field_id'], 'price_set_id');
602 CRM_Price_BAO_PriceSet::setIsQuickConfig($priceSetID, 0);
603 }
604 }
605 else {
606 // if there are label / values, create custom options for them
607 $labels = CRM_Utils_Array::value('label', $params);
608 $values = CRM_Utils_Array::value('value', $params);
609 $default = CRM_Utils_Array::value('default', $params);
610 $options = array();
611 if (!CRM_Utils_System::isNull($labels) && !CRM_Utils_System::isNull($values)) {
612 for ($i = 1; $i < self::NUM_OPTION; $i++) {
613 if (!empty($labels[$i]) && !CRM_Utils_System::isNull($values[$i])) {
614 $options[] = array(
615 'label' => trim($labels[$i]),
616 'value' => CRM_Utils_Rule::cleanMoney(trim($values[$i])),
617 'weight' => $i,
618 'is_active' => 1,
619 'is_default' => $default == $i,
620 );
621 }
622 }
623 if (!empty($options)) {
624 $params['default_fee_id'] = NULL;
625 if (empty($params['price_set_id'])) {
626 if (empty($params['price_field_id'])) {
627 $setParams['title'] = $eventTitle = ($this->_isTemplate) ? $this->_defaultValues['template_title'] : $this->_defaultValues['title'];
628 $eventTitle = strtolower(CRM_Utils_String::munge($eventTitle, '_', 245));
629 if (!CRM_Core_DAO::getFieldValue('CRM_Price_BAO_PriceSet', $eventTitle, 'id', 'name')) {
630 $setParams['name'] = $eventTitle;
631 }
632 elseif (!CRM_Core_DAO::getFieldValue('CRM_Price_BAO_PriceSet', $eventTitle . '_' . $this->_id, 'id', 'name')) {
633 $setParams['name'] = $eventTitle . '_' . $this->_id;
634 }
635 else {
636 $timeSec = explode('.', microtime(TRUE));
637 $setParams['name'] = $eventTitle . '_' . date('is', $timeSec[0]) . $timeSec[1];
638 }
639 $setParams['is_quick_config'] = 1;
640 $setParams['financial_type_id'] = $params['financial_type_id'];
641 $setParams['extends'] = CRM_Core_Component::getComponentID('CiviEvent');
642 $priceSet = CRM_Price_BAO_PriceSet::create($setParams);
643
644 $fieldParams['name'] = strtolower(CRM_Utils_String::munge($params['fee_label'], '_', 245));
645 $fieldParams['price_set_id'] = $priceSet->id;
646 }
647 else {
648 foreach ($params['price_field_value'] as $arrayID => $fieldValueID) {
649 if (empty($params['label'][$arrayID]) && empty($params['value'][$arrayID]) && !empty($fieldValueID)) {
650 CRM_Price_BAO_PriceFieldValue::setIsActive($fieldValueID, '0');
651 unset($params['price_field_value'][$arrayID]);
652 }
653 }
654 $fieldParams['id'] = CRM_Utils_Array::value('price_field_id', $params);
655 $fieldParams['option_id'] = $params['price_field_value'];
656
657 $priceSet = new CRM_Price_BAO_PriceSet();
658 $priceSet->id = CRM_Core_DAO::getFieldValue('CRM_Price_DAO_PriceField', CRM_Utils_Array::value('price_field_id', $params), 'price_set_id');
659
660 if ($this->_defaultValues['financial_type_id'] != $params['financial_type_id']) {
661 CRM_Core_DAO::setFieldValue('CRM_Price_DAO_PriceSet', $priceSet->id, 'financial_type_id', $params['financial_type_id']);
662 }
663 }
664 $fieldParams['label'] = $params['fee_label'];
665 $fieldParams['html_type'] = 'Radio';
666 CRM_Price_BAO_PriceSet::addTo('civicrm_event', $this->_id, $priceSet->id);
667 $fieldParams['option_label'] = $params['label'];
668 $fieldParams['option_amount'] = $params['value'];
669 $fieldParams['financial_type_id'] = $params['financial_type_id'];
670 foreach ($options as $value) {
671 $fieldParams['option_weight'][$value['weight']] = $value['weight'];
672 }
673 $fieldParams['default_option'] = $params['default'];
674 $priceField = CRM_Price_BAO_PriceField::create($fieldParams);
675 }
676 }
677 }
678
679 $discountPriceSets = !empty($this->_defaultValues['discount_price_set']) ? $this->_defaultValues['discount_price_set'] : array();
680 $discountFieldIDs = !empty($this->_defaultValues['discount_option_id']) ? $this->_defaultValues['discount_option_id'] : array();
681 if (CRM_Utils_Array::value('is_discount', $params) == 1) {
682 // if there are discounted set of label / values,
683 // create custom options for them
684 $labels = CRM_Utils_Array::value('discounted_label', $params);
685 $values = CRM_Utils_Array::value('discounted_value', $params);
686 $default = CRM_Utils_Array::value('discounted_default', $params);
687
688 if (!CRM_Utils_System::isNull($labels) && !CRM_Utils_System::isNull($values)) {
689 for ($j = 1; $j <= self::NUM_DISCOUNT; $j++) {
690 $discountOptions = array();
691 for ($i = 1; $i < self::NUM_OPTION; $i++) {
692 if (!empty($labels[$i]) &&
693 !CRM_Utils_System::isNull(CRM_Utils_Array::value($j, $values[$i]))
694 ) {
695 $discountOptions[] = array(
696 'label' => trim($labels[$i]),
697 'value' => CRM_Utils_Rule::cleanMoney(trim($values[$i][$j])),
698 'weight' => $i,
699 'is_active' => 1,
700 'is_default' => $default == $i,
701 );
702 }
703 }
704
705 if (!empty($discountOptions)) {
706 $fieldParams = array();
707 $params['default_discount_fee_id'] = NULL;
708 $keyCheck = $j - 1;
709 $setParams = array();
710 if (empty($discountPriceSets[$keyCheck])) {
711 if (!$eventTitle) {
712 $eventTitle = strtolower(CRM_Utils_String::munge($this->_defaultValues['title'], '_', 200));
713 }
714 $setParams['title'] = $params['discount_name'][$j];
715 if (!CRM_Core_DAO::getFieldValue('CRM_Price_BAO_PriceSet', $eventTitle . '_' . $params['discount_name'][$j], 'id', 'name')) {
716 $setParams['name'] = $eventTitle . '_' . $params['discount_name'][$j];
717 }
718 elseif (!CRM_Core_DAO::getFieldValue('CRM_Price_BAO_PriceSet', $eventTitle . '_' . $params['discount_name'][$j] . '_' . $this->_id, 'id', 'name')) {
719 $setParams['name'] = $eventTitle . '_' . $params['discount_name'][$j] . '_' . $this->_id;
720 }
721 else {
722 $timeSec = explode('.', microtime(TRUE));
723 $setParams['name'] = $eventTitle . '_' . $params['discount_name'][$j] . '_' . date('is', $timeSec[0]) . $timeSec[1];
724 }
725 $setParams['is_quick_config'] = 1;
726 $setParams['financial_type_id'] = $params['financial_type_id'];
727 $setParams['extends'] = CRM_Core_Component::getComponentID('CiviEvent');
728 $priceSet = CRM_Price_BAO_PriceSet::create($setParams);
729 $priceSetID = $priceSet->id;
730 }
731 else {
732 $priceSetID = $discountPriceSets[$j - 1];
733 $setParams = array(
734 'title' => $params['discount_name'][$j],
735 'id' => $priceSetID,
736 );
737 if ($this->_defaultValues['financial_type_id'] != $params['financial_type_id']) {
738 $setParams['financial_type_id'] = $params['financial_type_id'];
739 }
740 CRM_Price_BAO_PriceSet::create($setParams);
741 unset($discountPriceSets[$j - 1]);
742 $fieldParams['id'] = CRM_Core_DAO::getFieldValue('CRM_Price_BAO_PriceField', $priceSetID, 'id', 'price_set_id');
743 }
744
745 $fieldParams['name'] = $fieldParams['label'] = $params['fee_label'];
746 $fieldParams['is_required'] = 1;
747 $fieldParams['price_set_id'] = $priceSetID;
748 $fieldParams['html_type'] = 'Radio';
749 $fieldParams['financial_type_id'] = $params['financial_type_id'];
750 foreach ($discountOptions as $value) {
751 $fieldParams['option_label'][$value['weight']] = $value['label'];
752 $fieldParams['option_amount'][$value['weight']] = $value['value'];
753 $fieldParams['option_weight'][$value['weight']] = $value['weight'];
754 if (!empty($value['is_default'])) {
755 $fieldParams['default_option'] = $value['weight'];
756 }
757 if (!empty($discountFieldIDs[$j]) && !empty($discountFieldIDs[$j][$value['weight']])) {
758 $fieldParams['option_id'][$value['weight']] = $discountFieldIDs[$j][$value['weight']];
759 unset($discountFieldIDs[$j][$value['weight']]);
760 }
761 }
762 //create discount priceset
763 $priceField = CRM_Price_BAO_PriceField::create($fieldParams);
764 if (!empty($discountFieldIDs[$j])) {
765 foreach ($discountFieldIDs[$j] as $fID) {
766 CRM_Price_BAO_PriceFieldValue::setIsActive($fID, '0');
767 }
768 }
769
770 $discountParams = array(
771 'entity_table' => 'civicrm_event',
772 'entity_id' => $this->_id,
773 'price_set_id' => $priceSetID,
774 'start_date' => CRM_Utils_Date::processDate($params['discount_start_date'][$j]),
775 'end_date' => CRM_Utils_Date::processDate($params['discount_end_date'][$j]),
776 );
777 CRM_Core_BAO_Discount::add($discountParams);
778 }
779 }
780 }
781 }
782 if (!empty($discountPriceSets)) {
783 foreach ($discountPriceSets as $setId) {
784 CRM_Price_BAO_PriceSet::setIsQuickConfig($setId, 0);
785 }
786 }
787 }
788 }
789 else {
790 if (!empty($params['price_field_id'])) {
791 $priceSetID = CRM_Core_DAO::getFieldValue('CRM_Price_DAO_PriceField', $params['price_field_id'], 'price_set_id');
792 CRM_Price_BAO_PriceSet::setIsQuickConfig($priceSetID, 0);
793 }
794 $params['financial_type_id'] = '';
795 $params['is_pay_later'] = 0;
796 $params['is_billing_required'] = 0;
797 }
798
799 //update 'is_billing_required'
800 if (empty($params['is_pay_later'])) {
801 $params['is_billing_required'] = FALSE;
802 }
803
804 //update events table
805 $params['id'] = $this->_id;
806 // skip update of financial type in price set
807 $params['skipFinancialType'] = TRUE;
808 CRM_Event_BAO_Event::add($params);
809
810 // Update tab "disabled" css class
811 $this->ajaxResponse['tabValid'] = !empty($params['is_monetary']);
812 parent::endPostProcess();
813 }
814
815 /**
816 * Return a descriptive name for the page, used in wizard header
817 *
818 * @return string
819 */
820 public function getTitle() {
821 return ts('Event Fees');
822 }
823
824 }