function preProcess() {
parent::preProcess();
- CRM_Contribute_Form_Contribution_Main::preProcessPaymentOptions($this);
- if ($this->_snippet) {
- return;
- }
-
//CRM-4320.
//here we can't use parent $this->_allowWaitlist as user might
//walk back and we maight set this value in this postProcess.
//(we set when spaces < group count and want to allow become part of waiting )
-
$eventFull = CRM_Event_BAO_Participant::eventFull($this->_eventId, FALSE, CRM_Utils_Array::value('has_waitlist', $this->_values['event']));
+ // Get payment processors if appropriate for this event
+ // We hide the payment fields if the event is full or requires approval,
+ // and the current user has not yet been approved CRM-12279
+ $noFees = (($eventFull || $this->_requireApproval) && !$this->_allowConfirmation);
+ CRM_Contribute_Form_Contribution_Main::preProcessPaymentOptions($this, $noFees);
+ if ($this->_snippet) {
+ return;
+ }
+
$this->_allowWaitlist = FALSE;
if ($eventFull && !$this->_allowConfirmation &&
CRM_Utils_Array::value('has_waitlist', $this->_values['event'])
if ($this->_allowConfirmation) {
CRM_Event_Form_EventFees::preProcess($this);
}
-
- if (CRM_Utils_Array::value('hidden_processor', $_POST)) {
- $this->set('type', CRM_Utils_Array::value('payment_processor', $_POST));
- $this->set('mode', $this->_mode);
- $this->set('paymentProcessor', $this->_paymentProcessor);
-
- CRM_Core_Payment_ProcessorForm::preProcess($this);
- CRM_Core_Payment_ProcessorForm::buildQuickForm($this);
- }
-
}
/**
return;
}
- $contactID = parent::getContactID();
+ $contactID = $this->getContactID();
if ($contactID) {
//@todo CRM-11915 I observed that even when the billing block is not present the routine to retrieve the billing defaults is still called - which seems a bit redundant.
$names = array(
// now fix all state country selectors
CRM_Core_BAO_Address::fixAllStateSelects($this, $this->_defaults);
- if ($this->_ppType) {
+ if ($this->_snippet) {
return $this->_defaults;
}
}
}
- $contactID = parent::getContactID();
+ $contactID = $this->getContactID();
$this->assign('contact_id', $contactID);
- $display_name = '';
- if ($contactID) {
- $display_name = CRM_Contact_BAO_Contact::displayName($contactID);
- }
- $this->assign('display_name', $display_name);
+ $this->assign('display_name', CRM_Contact_BAO_Contact::displayName($contactID));
$config = CRM_Core_Config::singleton();
$this->add('hidden', 'scriptFee', NULL);
}
$pps = NULL;
- $this->_paymentProcessors = $this->get('paymentProcessors');
if (!empty($this->_paymentProcessors)) {
$pps = $this->_paymentProcessors;
foreach ($pps as $key => & $name) {
$this->assign('bypassPayment', $bypassPayment);
$this->assign('showHidePaymentInformation', $showHidePaymentInformation);
- $userID = parent::getContactID();
+ $userID = $this->getContactID();
if (!$userID) {
$createCMSUser = FALSE;
}
// return if this is express mode
$config = CRM_Core_Config::singleton();
- if ($self->_paymentProcessor['billing_mode'] & CRM_Core_Payment::BILLING_MODE_BUTTON) {
+ if ($self->_paymentProcessor &&
+ $self->_paymentProcessor['billing_mode'] & CRM_Core_Payment::BILLING_MODE_BUTTON
+ ) {
if (CRM_Utils_Array::value($self->_expressButtonName . '_x', $fields) ||
CRM_Utils_Array::value($self->_expressButtonName . '_y', $fields) ||
CRM_Utils_Array::value($self->_expressButtonName, $fields)
) {
return empty($errors) ? TRUE : $errors;
}
- if (property_exists($self, '_paymentFields') && !empty($self->_paymentFields )) {
- foreach ($self->_paymentFields as $name => $fld) {
- if ($fld['is_required'] &&
- CRM_Utils_System::isNull(CRM_Utils_Array::value($name, $fields))
- ) {
- $errors[$name] = ts('%1 is a required field.', array(1 => $fld['title']));
- }
- }
+ if (!empty($self->_paymentFields)) {
+ CRM_Core_Form::validateMandatoryFields($self->_paymentFields, $fields, $errors);
}
+ CRM_Core_Payment_Form::validateCreditCard($fields, $errors);
}
- // make sure that credit card number and cvv are valid
- if (CRM_Utils_Array::value('credit_card_type', $fields)) {
- if (CRM_Utils_Array::value('credit_card_number', $fields) &&
- !CRM_Utils_Rule::creditCardNumber($fields['credit_card_number'], $fields['credit_card_type'])
- ) {
- $errors['credit_card_number'] = ts('Please enter a valid Credit Card Number');
- }
- if (CRM_Utils_Array::value('cvv2', $fields) &&
- !CRM_Utils_Rule::cvv($fields['cvv2'], $fields['credit_card_type'])
- ) {
- $errors['cvv2'] = ts('Please enter a valid Credit Card Verification Number');
- }
- }
foreach (CRM_Contact_BAO_Contact::$_greetingTypes as $greeting) {
if ($greetingType = CRM_Utils_Array::value($greeting, $fields)) {
$customizedValue = CRM_Core_OptionGroup::getValue($greeting, 'Customized', 'name');
$this->_params[] = $params;
$this->set('params', $this->_params);
- if ($this->_paymentProcessor['billing_mode'] & CRM_Core_Payment::BILLING_MODE_BUTTON) {
+ if ($this->_paymentProcessor &&
+ $this->_paymentProcessor['billing_mode'] & CRM_Core_Payment::BILLING_MODE_BUTTON
+ ) {
//get the button name
$buttonName = $this->controller->getButtonName();
if (in_array($buttonName,
CRM_Utils_System::redirect($paymentURL);
}
}
- elseif ($this->_paymentProcessor['billing_mode'] & CRM_Core_Payment::BILLING_MODE_NOTIFY) {
+ elseif ($this->_paymentProcessor &&
+ $this->_paymentProcessor['billing_mode'] & CRM_Core_Payment::BILLING_MODE_NOTIFY
+ ) {
$this->set('contributeMode', 'notify');
}
}
$contactID = $value['contact_id'];
}
else {
- $contactID = parent::getContactID();
+ $contactID = $this->getContactID();
}
CRM_Event_Form_Registration_Confirm::fixLocationFields($value, $fields);
// we dont store in userID in case the user is doing multiple
// transactions etc
// for things like tell a friend
- if (!parent::getContactID() && CRM_Utils_Array::value('is_primary', $value)) {
+ if (!$this->getContactID() && CRM_Utils_Array::value('is_primary', $value)) {
$session->set('transaction.userID', $contactID);
}
* @return void
* @access public
*/
- function checkRegistration($fields, &$self, $isAdditional = FALSE, $returnContactId = FALSE, $useDedupeRules = FALSE) {
+ static function checkRegistration($fields, &$self, $isAdditional = FALSE, $returnContactId = FALSE, $useDedupeRules = FALSE) {
// CRM-3907, skip check for preview registrations
// CRM-4320 participant need to walk wizard
if (!$returnContactId &&
$contactID = NULL;
$session = CRM_Core_Session::singleton();
if (!$isAdditional) {
- $contactID = parent::getContactID();
+ $contactID = $self->getContactID();
}
- if (!$contactID &&
- is_array($fields) &&
- !empty($fields)
- ) {
+ if (!$contactID && is_array($fields) && $fields) {
//CRM-6996
//as we are allowing w/ same email address,