3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.7 |
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2015 |
7 +--------------------------------------------------------------------+
8 | This file is a part of CiviCRM. |
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. |
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. |
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 +--------------------------------------------------------------------+
32 * @copyright CiviCRM LLC (c) 2004-2015
38 * This class generates form components for processing a participation fee block
40 class CRM_Event_Form_EventFees
{
43 * Set variables up before form is built.
45 * @param CRM_Core_Form $form
47 public static function preProcess(&$form) {
48 //as when call come from register.php
49 if (!$form->_eventId
) {
50 $form->_eventId
= CRM_Utils_Request
::retrieve('eventId', 'Positive', $form);
53 $form->_pId
= CRM_Utils_Request
::retrieve('participantId', 'Positive', $form);
54 $form->_discountId
= CRM_Utils_Request
::retrieve('discountId', 'Positive', $form);
56 $form->_fromEmails
= CRM_Event_BAO_Event
::getFromEmailIds($form->_eventId
);
58 //CRM-6907 set event specific currency.
59 if ($form->_eventId
&&
60 ($currency = CRM_Core_DAO
::getFieldValue('CRM_Event_DAO_Event', $form->_eventId
, 'currency'))
62 CRM_Core_Config
::singleton()->defaultCurrency
= $currency;
67 * This function sets the default values for the form in edit/view mode
68 * the default values are retrieved from the database
70 * @param CRM_Core_Form $form
72 public static function setDefaultValues(&$form) {
75 if ($form->_eventId
) {
76 //get receipt text and financial type
77 $returnProperities = array('confirm_email_text', 'financial_type_id', 'campaign_id', 'start_date');
79 CRM_Core_DAO
::commonRetrieveAll('CRM_Event_DAO_Event', 'id', $form->_eventId
, $details, $returnProperities);
80 if (!empty($details[$form->_eventId
]['financial_type_id'])) {
81 $defaults[$form->_pId
]['financial_type_id'] = $details[$form->_eventId
]['financial_type_id'];
87 $params = array('id' => $form->_pId
);
89 CRM_Event_BAO_Participant
::getValues($params, $defaults, $ids);
90 if ($form->_action
== CRM_Core_Action
::UPDATE
) {
92 if (!empty($form->_values
['discount'])) {
93 foreach ($form->_values
['discount'] as $key => $value) {
94 $value = current($value);
95 $discounts[$key] = $value['name'];
99 if ($form->_discountId
&& !empty($discounts[$defaults[$form->_pId
]['discount_id']])) {
100 $form->assign('discount', $discounts[$defaults[$form->_pId
]['discount_id']]);
103 $form->assign('fee_amount', CRM_Utils_Array
::value('fee_amount', $defaults[$form->_pId
]));
104 $form->assign('fee_level', CRM_Utils_Array
::value('fee_level', $defaults[$form->_pId
]));
106 $defaults[$form->_pId
]['send_receipt'] = 0;
109 $defaults[$form->_pId
]['send_receipt'] = (strtotime(CRM_Utils_Array
::value('start_date', $details[$form->_eventId
])) >= time()) ?
1 : 0;
110 if ($form->_eventId
&& !empty($details[$form->_eventId
]['confirm_email_text'])) {
112 $defaults[$form->_pId
]['receipt_text'] = $details[$form->_eventId
]['confirm_email_text'];
115 list($defaults[$form->_pId
]['receive_date'], $defaults[$form->_pId
]['receive_date_time']) = CRM_Utils_Date
::setDateDefaults();
118 //CRM-11601 we should keep the record contribution
119 //true by default while adding participant
120 if ($form->_action
== CRM_Core_Action
::ADD
&& !$form->_mode
&& $form->_isPaidEvent
) {
121 $defaults[$form->_pId
]['record_contribution'] = 1;
125 if (empty($defaults['payment_instrument_id'])) {
126 $defaults[$form->_pId
]['payment_instrument_id'] = key(CRM_Core_OptionGroup
::values('payment_instrument', FALSE, FALSE, FALSE, 'AND is_default = 1'));
129 $config = CRM_Core_Config
::singleton();
130 // set default country from config if no country set
131 if (empty($defaults[$form->_pId
]["billing_country_id-{$form->_bltID}"])) {
132 $defaults[$form->_pId
]["billing_country_id-{$form->_bltID}"] = $config->defaultContactCountry
;
135 if (empty($defaults["billing_state_province_id-{$form->_bltID}"])) {
136 $defaults[$form->_pId
]["billing_state_province_id-{$form->_bltID}"] = $config->defaultContactStateProvince
;
139 $billingDefaults = $form->getProfileDefaults('Billing', $form->_contactId
);
140 $defaults[$form->_pId
] = array_merge($defaults[$form->_pId
], $billingDefaults);
142 // // hack to simplify credit card entry for testing
143 // $defaults[$form->_pId]['credit_card_type'] = 'Visa';
144 // $defaults[$form->_pId]['credit_card_number'] = '4807731747657838';
145 // $defaults[$form->_pId]['cvv2'] = '000';
146 // $defaults[$form->_pId]['credit_card_exp_date'] = array( 'Y' => '2012', 'M' => '05' );
149 // if user has selected discount use that to set default
150 if (isset($form->_discountId
)) {
151 $defaults[$form->_pId
]['discount_id'] = $form->_discountId
;
153 //hack to set defaults for already selected discount value
154 if ($form->_action
== CRM_Core_Action
::UPDATE
&& !$form->_originalDiscountId
) {
155 $form->_originalDiscountId
= $defaults[$form->_pId
]['discount_id'];
156 if ($form->_originalDiscountId
) {
157 $defaults[$form->_pId
]['discount_id'] = $form->_originalDiscountId
;
160 $discountId = $form->_discountId
;
163 $discountId = CRM_Core_BAO_Discount
::findSet($form->_eventId
, 'civicrm_event');
167 $priceSetId = CRM_Core_DAO
::getFieldValue('CRM_Core_BAO_Discount', $discountId, 'price_set_id');
170 $priceSetId = CRM_Price_BAO_PriceSet
::getFor('civicrm_event', $form->_eventId
);
173 if (($form->_action
== CRM_Core_Action
::ADD
) && $form->_eventId
&& $discountId) {
174 // this case is for add mode, where we show discount automatically
175 $defaults[$form->_pId
]['discount_id'] = $discountId;
179 // get price set default values, CRM-4090
180 if (in_array(get_class($form),
182 'CRM_Event_Form_Participant',
183 'CRM_Event_Form_Registration_Register',
184 'CRM_Event_Form_Registration_AdditionalParticipant',
187 $priceSetValues = self
::setDefaultPriceSet($form->_pId
, $form->_eventId
);
188 if (!empty($priceSetValues)) {
189 $defaults[$form->_pId
] = array_merge($defaults[$form->_pId
], $priceSetValues);
193 if ($form->_action
== CRM_Core_Action
::ADD
&& !empty($form->_priceSet
['fields'])) {
194 foreach ($form->_priceSet
['fields'] as $key => $val) {
195 foreach ($val['options'] as $keys => $values) {
196 if ($values['is_default']) {
197 if (get_class($form) != 'CRM_Event_Form_Participant' && !empty($values['is_full'])) {
201 if ($val['html_type'] == 'CheckBox') {
202 $defaults[$form->_pId
]["price_{$key}"][$keys] = 1;
205 $defaults[$form->_pId
]["price_{$key}"] = $keys;
212 $form->assign('totalAmount', CRM_Utils_Array
::value('fee_amount', $defaults[$form->_pId
]));
213 if ($form->_action
== CRM_Core_Action
::UPDATE
) {
214 $fee_level = $defaults[$form->_pId
]['fee_level'];
215 CRM_Event_BAO_Participant
::fixEventLevel($fee_level);
216 $form->assign('fee_level', $fee_level);
217 $form->assign('fee_amount', CRM_Utils_Array
::value('fee_amount', $defaults[$form->_pId
]));
222 if (!empty($defaults[$form->_pId
]['participant_fee_currency'])) {
223 $form->assign('fee_currency', $defaults[$form->_pId
]['participant_fee_currency']);
227 if ($contriId = $form->get('onlinePendingContributionId')) {
228 $contribution = new CRM_Contribute_DAO_Contribution();
229 $contribution->id
= $contriId;
230 $contribution->find(TRUE);
233 'payment_instrument_id',
234 'contribution_status_id',
238 if ($f == 'receive_date') {
239 list($defaults[$form->_pId
]['receive_date']) = CRM_Utils_Date
::setDateDefaults($contribution->$f);
242 $defaults[$form->_pId
][$f] = $contribution->$f;
246 return $defaults[$form->_pId
];
250 * This function sets the default values for price set.
253 * @param int $participantID
254 * @param int $eventID
255 * @param bool $includeQtyZero
259 public static function setDefaultPriceSet($participantID, $eventID = NULL, $includeQtyZero = TRUE) {
261 if (!$eventID && $participantID) {
262 $eventID = CRM_Core_DAO
::getFieldValue('CRM_Event_DAO_Participant', $participantID, 'event_id');
264 if (!$participantID ||
!$eventID) {
269 $priceSetID = CRM_Price_BAO_PriceSet
::getFor('civicrm_event', $eventID);
274 // use line items for setdefault price set fields, CRM-4090
275 $lineItems[$participantID] = CRM_Price_BAO_LineItem
::getLineItems($participantID, 'participant', NULL, $includeQtyZero);
277 if (is_array($lineItems[$participantID]) &&
278 !CRM_Utils_System
::isNull($lineItems[$participantID])
281 $priceFields = $htmlTypes = $optionValues = array();
282 foreach ($lineItems[$participantID] as $lineId => $items) {
283 $priceFieldId = CRM_Utils_Array
::value('price_field_id', $items);
284 $priceOptionId = CRM_Utils_Array
::value('price_field_value_id', $items);
285 if ($priceFieldId && $priceOptionId) {
286 $priceFields[$priceFieldId][] = $priceOptionId;
290 if (empty($priceFields)) {
294 // get all price set field html types.
297 FROM civicrm_price_field
298 WHERE id IN (' . implode(',', array_keys($priceFields)) . ')';
299 $fieldDAO = CRM_Core_DAO
::executeQuery($sql);
300 while ($fieldDAO->fetch()) {
301 $htmlTypes[$fieldDAO->id
] = $fieldDAO->html_type
;
304 foreach ($lineItems[$participantID] as $lineId => $items) {
305 $fieldId = $items['price_field_id'];
306 $htmlType = CRM_Utils_Array
::value($fieldId, $htmlTypes);
311 if ($htmlType == 'Text') {
312 $defaults["price_{$fieldId}"] = $items['qty'];
315 $fieldOptValues = CRM_Utils_Array
::value($fieldId, $priceFields);
316 if (!is_array($fieldOptValues)) {
320 foreach ($fieldOptValues as $optionId) {
321 if ($htmlType == 'CheckBox') {
322 $defaults["price_{$fieldId}"][$optionId] = TRUE;
325 $defaults["price_{$fieldId}"] = $optionId;
337 * Build the form object.
339 * @param CRM_Core_Form $form
341 public static function buildQuickForm(&$form) {
342 if ($form->_eventId
) {
343 $form->_isPaidEvent
= CRM_Core_DAO
::getFieldValue('CRM_Event_DAO_Event', $form->_eventId
, 'is_monetary');
344 if ($form->_isPaidEvent
) {
345 $form->addElement('hidden', 'hidden_feeblock', 1);
348 // make sure this is for backoffice registration.
349 if ($form->getName() == 'Participant') {
350 $eventfullMsg = CRM_Event_BAO_Participant
::eventFullMessage($form->_eventId
, $form->_pId
);
351 $form->addElement('hidden', 'hidden_eventFullMsg', $eventfullMsg, array('id' => 'hidden_eventFullMsg'));
356 if (CRM_Core_DAO
::getFieldValue('CRM_Event_DAO_ParticipantPayment',
357 $form->_pId
, 'contribution_id', 'participant_id'
360 $form->_online
= TRUE;
364 if ($form->_isPaidEvent
) {
365 $params = array('id' => $form->_eventId
);
366 CRM_Event_BAO_Event
::retrieve($params, $event);
368 //retrieve custom information
369 $form->_values
= array();
370 CRM_Event_Form_Registration
::initEventFee($form, $event['id']);
371 CRM_Event_Form_Registration_Register
::buildAmount($form, TRUE, $form->_discountId
);
373 $invoiceSettings = CRM_Core_BAO_Setting
::getItem(CRM_Core_BAO_Setting
::CONTRIBUTE_PREFERENCES_NAME
, 'contribution_invoice_settings');
374 $invoicing = CRM_Utils_Array
::value('invoicing', $invoiceSettings);
376 if (!CRM_Utils_System
::isNull(CRM_Utils_Array
::value('line_items', $form->_values
))) {
377 $lineItem[] = $form->_values
['line_items'];
378 foreach ($form->_values
['line_items'] as $key => $value) {
379 $totalTaxAmount = $value['tax_amount'] +
$totalTaxAmount;
383 $form->assign('totalTaxAmount', $totalTaxAmount);
385 $form->assign('lineItem', empty($lineItem) ?
FALSE : $lineItem);
386 $discounts = array();
387 if (!empty($form->_values
['discount'])) {
388 foreach ($form->_values
['discount'] as $key => $value) {
389 $value = current($value);
390 $discounts[$key] = $value['name'];
393 $element = $form->add('select', 'discount_id',
396 0 => ts('- select -'),
399 array('class' => "crm-select2")
402 if ($form->_online
) {
406 if (CRM_Financial_BAO_FinancialType
::isACLFinancialTypeStatus()
407 && !CRM_Utils_Array
::value('fee', $form->_values
)
408 && CRM_Utils_Array
::value('snippet', $_REQUEST) == CRM_Core_Smarty
::PRINT_NOFORM
410 $form->assign('isFTPermissionDenied', TRUE);
414 CRM_Core_Payment_Form
::buildPaymentForm($form, $form->_paymentProcessor
, FALSE, TRUE);
416 elseif (!$form->_mode
) {
417 $form->addElement('checkbox', 'record_contribution', ts('Record Payment?'), NULL,
418 array('onclick' => "return showHideByValue('record_contribution','','payment_information','table-row','radio',false);")
420 // Check permissions for financial type first
421 if (CRM_Financial_BAO_FinancialType
::isACLFinancialTypeStatus()) {
422 CRM_Financial_BAO_FinancialType
::getAvailableFinancialTypes($financialTypes, $form->_action
);
425 $financialTypes = CRM_Contribute_PseudoConstant
::financialType();
428 $form->add('select', 'financial_type_id',
429 ts('Financial Type'),
430 array('' => ts('- select -')) +
$financialTypes
433 $form->addDateTime('receive_date', ts('Received'), FALSE, array('formatType' => 'activityDateTime'));
435 $form->add('select', 'payment_instrument_id',
436 ts('Payment Method'),
437 array('' => ts('- select -')) + CRM_Contribute_PseudoConstant
::paymentInstrument(),
438 FALSE, array('onChange' => "return showHideByValue('payment_instrument_id','4','checkNumber','table-row','select',false);")
440 // don't show transaction id in batch update mode
441 $path = CRM_Utils_System
::currentPath();
442 $form->assign('showTransactionId', FALSE);
443 if ($path != 'civicrm/contact/search/basic') {
444 $form->add('text', 'trxn_id', ts('Transaction ID'));
445 $form->addRule('trxn_id', ts('Transaction ID already exists in Database.'),
446 'objectExists', array('CRM_Contribute_DAO_Contribution', $form->_eventId
, 'trxn_id')
448 $form->assign('showTransactionId', TRUE);
451 $status = CRM_Contribute_PseudoConstant
::contributionStatus();
453 // CRM-14417 suppressing contribution statuses that are NOT relevant to new participant registrations
454 $statusName = CRM_Contribute_PseudoConstant
::contributionStatus(NULL, 'name');
463 unset($status[CRM_Utils_Array
::key($suppress, $statusName)]);
466 $form->add('select', 'contribution_status_id',
467 ts('Payment Status'), $status
470 $form->add('text', 'check_number', ts('Check Number'),
471 CRM_Core_DAO
::getAttribute('CRM_Contribute_DAO_Contribution', 'check_number')
474 $form->add('text', 'total_amount', ts('Amount'),
475 CRM_Core_DAO
::getAttribute('CRM_Contribute_DAO_Contribution', 'total_amount')
480 $form->add('text', 'amount', ts('Event Fee(s)'));
482 $form->assign('onlinePendingContributionId', $form->get('onlinePendingContributionId'));
484 $form->assign('paid', $form->_isPaidEvent
);
486 $form->addElement('checkbox',
488 ts('Send Confirmation?'), NULL,
489 array('onclick' => "showHideByValue('send_receipt','','notice','table-row','radio',false); showHideByValue('send_receipt','','from-email','table-row','radio',false);")
492 $form->add('select', 'from_email_address', ts('Receipt From'), $form->_fromEmails
['from_email_id']);
494 $form->add('textarea', 'receipt_text', ts('Confirmation Message'));
496 // Retrieve the name and email of the contact - form will be the TO for receipt email ( only if context is not standalone)
497 if ($form->_context
!= 'standalone') {
498 if ($form->_contactId
) {
499 list($form->_contributorDisplayName
,
500 $form->_contributorEmail
501 ) = CRM_Contact_BAO_Contact_Location
::getEmailDetails($form->_contactId
);
502 $form->assign('email', $form->_contributorEmail
);
505 //show email block for batch update for event
506 $form->assign('batchEmail', TRUE);
510 $mailingInfo = CRM_Core_BAO_Setting
::getItem(CRM_Core_BAO_Setting
::MAILING_PREFERENCES_NAME
,
513 $form->assign('outBound_option', $mailingInfo['outBound_option']);
514 $form->assign('hasPayment', $form->_paymentId
);