3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.5 |
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2014 |
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 +--------------------------------------------------------------------+
31 * @copyright CiviCRM LLC (c) 2004-2014
37 * This class generates form components for processing a Contribution
40 class CRM_Contribute_Form_Contribution_Main
extends CRM_Contribute_Form_ContributionBase
{
43 *Define default MembershipType Id
46 public $_defaultMemTypeId;
48 public $_relatedOrganizationFound;
50 public $_onBehalfRequired = FALSE;
51 public $_onbehalf = FALSE;
52 public $_paymentProcessors;
55 public $_membershipTypeValues;
57 public $_useForMember;
63 * Function to set variables up before form is built
68 public function preProcess() {
71 self
::preProcessPaymentOptions($this);
73 // Make the contributionPageID avilable to the template
74 $this->assign('contributionPageID', $this->_id
);
75 $this->assign('isShare', CRM_Utils_Array
::value('is_share', $this->_values
));
76 $this->assign('isConfirmEnabled', CRM_Utils_Array
::value('is_confirm_enabled', $this->_values
));
78 // make sure we have right permission to edit this user
79 $csContactID = $this->getContactID();
80 $reset = CRM_Utils_Request
::retrieve('reset', 'Boolean', CRM_Core_DAO
::$_nullObject);
81 $mainDisplay = CRM_Utils_Request
::retrieve('_qf_Main_display', 'Boolean', CRM_Core_DAO
::$_nullObject);
84 $this->assign('reset', $reset);
88 $this->assign('mainDisplay', $mainDisplay);
91 // Possible values for 'is_for_organization':
92 // * 0 - org profile disabled
93 // * 1 - org profile optional
94 // * 2 - org profile required
95 $this->_onbehalf
= FALSE;
96 if (!empty($this->_values
['is_for_organization'])) {
97 if ($this->_values
['is_for_organization'] == 2) {
98 $this->_onBehalfRequired
= TRUE;
100 // Add organization profile if 1 of the following are true:
101 // If the org profile is required
102 if ($this->_onBehalfRequired ||
103 // Or we are building the form for the first time
105 // Or the user has submitted the form and checked the "On Behalf" checkbox
106 !empty($_POST['is_for_organization'])
108 $this->_onbehalf
= TRUE;
109 CRM_Contribute_Form_Contribution_OnBehalfOf
::preProcess($this);
112 $this->assign('onBehalfRequired', $this->_onBehalfRequired
);
114 if ($this->_honor_block_is_active
) {
115 CRM_Contact_Form_ProfileContact
::preprocess($this);
118 if ($this->_snippet
) {
119 $this->assign('isOnBehalfCallback', CRM_Utils_Array
::value('onbehalf', $_GET, FALSE));
123 if (!empty($this->_pcpInfo
['id']) && !empty($this->_pcpInfo
['intro_text'])) {
124 $this->assign('intro_text', $this->_pcpInfo
['intro_text']);
126 elseif (!empty($this->_values
['intro_text'])) {
127 $this->assign('intro_text', $this->_values
['intro_text']);
130 $qParams = "reset=1&id={$this->_id}";
131 if ($pcpId = CRM_Utils_Array
::value('pcp_id', $this->_pcpInfo
)) {
132 $qParams .= "&pcpId={$pcpId}";
134 $this->assign('qParams', $qParams);
136 if (!empty($this->_values
['footer_text'])) {
137 $this->assign('footer_text', $this->_values
['footer_text']);
141 if (!empty($this->_values
['is_for_organization'])) {
142 $msg = ts('Mixed profile not allowed for on behalf of registration/sign up.');
143 if ($preID = CRM_Utils_Array
::value('custom_pre_id', $this->_values
)) {
144 $preProfile = CRM_Core_BAO_UFGroup
::profileGroups($preID);
146 'Individual', 'Organization', 'Household') as $contactType) {
147 if (in_array($contactType, $preProfile) &&
148 (in_array('Membership', $preProfile) ||
149 in_array('Contribution', $preProfile)
152 CRM_Core_Error
::fatal($msg);
157 if ($postID = CRM_Utils_Array
::value('custom_post_id', $this->_values
)) {
158 $postProfile = CRM_Core_BAO_UFGroup
::profileGroups($postID);
160 'Individual', 'Organization', 'Household') as $contactType) {
161 if (in_array($contactType, $postProfile) &&
162 (in_array('Membership', $postProfile) ||
163 in_array('Contribution', $postProfile)
166 CRM_Core_Error
::fatal($msg);
174 * set the default values
182 function setDefaultValues() {
183 // check if the user is registered and we have a contact ID
184 $contactID = $this->getContactID();
186 if (!empty($contactID)) {
188 $removeCustomFieldTypes = array('Contribution', 'Membership');
189 $contribFields = CRM_Contribute_BAO_Contribution
::getContributionFields();
191 // remove component related fields
192 foreach ($this->_fields
as $name => $dontCare) {
193 //don't set custom data Used for Contribution (CRM-1344)
194 if (substr($name, 0, 7) == 'custom_') {
195 $id = substr($name, 7);
196 if (!CRM_Core_BAO_CustomGroup
::checkCustomField($id, $removeCustomFieldTypes)) {
199 // ignore component fields
201 elseif (array_key_exists($name, $contribFields) ||
(substr($name, 0, 11) == 'membership_') ||
(substr($name, 0, 13) == 'contribution_')) {
207 if (!empty($fields)) {
208 CRM_Core_BAO_UFGroup
::setProfileDefaults($contactID, $fields, $this->_defaults
);
211 $billingDefaults = $this->getProfileDefaults('Billing', $contactID);
212 $this->_defaults
= array_merge($this->_defaults
, $billingDefaults);
215 //set custom field defaults set by admin if value is not set
216 if (!empty($this->_fields
)) {
217 //load default campaign from page.
218 if (array_key_exists('contribution_campaign_id', $this->_fields
)) {
219 $this->_defaults
['contribution_campaign_id'] = CRM_Utils_Array
::value('campaign_id', $this->_values
);
222 //set custom field defaults
223 foreach ($this->_fields
as $name => $field) {
224 if ($customFieldID = CRM_Core_BAO_CustomField
::getKeyID($name)) {
225 if (!isset($this->_defaults
[$name])) {
226 CRM_Core_BAO_CustomField
::setProfileDefaults($customFieldID, $name, $this->_defaults
,
227 NULL, CRM_Profile_Form
::MODE_REGISTER
234 // // hack to simplify credit card entry for testing
235 // $this->_defaults['credit_card_type'] = 'Visa';
236 // $this->_defaults['amount'] = 168;
237 // $this->_defaults['credit_card_number'] = '4111111111111111';
238 // $this->_defaults['cvv2'] = '000';
239 // $this->_defaults['credit_card_exp_date'] = array('Y' => '2014', 'M' => '05');
241 // // hack to simplify direct debit entry for testing
242 // $this->_defaults['account_holder'] = 'Max Müller';
243 // $this->_defaults['bank_account_number'] = '12345678';
244 // $this->_defaults['bank_identification_number'] = '12030000';
245 // $this->_defaults['bank_name'] = 'Bankname';
247 //build set default for pledge overdue payment.
248 if (!empty($this->_values
['pledge_id'])) {
249 //get all pledge payment records of current pledge id.
250 $pledgePayments = array();
252 //used to record completed pledge payment ids used later for honor default
253 $completedContributionIds = array();
255 $pledgePayments = CRM_Pledge_BAO_PledgePayment
::getPledgePayments($this->_values
['pledge_id']);
258 foreach ($pledgePayments as $payId => $value) {
259 if ($value['status'] == 'Overdue') {
260 $this->_defaults
['pledge_amount'][$payId] = 1;
262 elseif (!$duePayment && $value['status'] == 'Pending') {
263 $this->_defaults
['pledge_amount'][$payId] = 1;
266 elseif ($value['status'] == 'Completed' && $value['contribution_id']) {
267 $completedContributionIds[] = $value['contribution_id'];
271 if ($this->_honor_block_is_active
&& count($completedContributionIds)) {
272 $softCredit = array();
273 foreach ($completedContributionIds as $id) {
274 $softCredit = CRM_Contribute_BAO_ContributionSoft
::getSoftContribution($id);
276 if (isset($softCredit['soft_credit'])) {
277 $this->_defaults
['soft_credit_type_id'] = $softCredit['soft_credit'][1]['soft_credit_type'];
279 //since honoree profile fieldname of fields are prefixed with 'honor'
280 //we need to reformat the fieldname to append prefix during setting default values
281 CRM_Core_BAO_UFGroup
::setProfileDefaults(
282 $softCredit['soft_credit'][1]['contact_id'],
283 CRM_Core_BAO_UFGroup
::getFields($this->_honoreeProfileId
),
286 foreach ($defaults as $fieldName => $value) {
287 $this->_defaults
['honor[' . $fieldName . ']'] = $value;
292 elseif (!empty($this->_values
['pledge_block_id'])) {
293 //set default to one time contribution.
294 $this->_defaults
['is_pledge'] = 0;
297 // to process Custom data that are appended to URL
298 $getDefaults = CRM_Core_BAO_CustomGroup
::extractGetParams($this, "'Contact', 'Individual', 'Contribution'");
299 if (!empty($getDefaults)) {
300 $this->_defaults
= array_merge($this->_defaults
, $getDefaults);
303 $config = CRM_Core_Config
::singleton();
304 // set default country from config if no country set
305 if (empty($this->_defaults
["billing_country_id-{$this->_bltID}"])) {
306 $this->_defaults
["billing_country_id-{$this->_bltID}"] = $config->defaultContactCountry
;
309 // set default state/province from config if no state/province set
310 if (empty($this->_defaults
["billing_state_province_id-{$this->_bltID}"])) {
311 $this->_defaults
["billing_state_province_id-{$this->_bltID}"] = $config->defaultContactStateProvince
;
314 // now fix all state country selectors
315 CRM_Core_BAO_Address
::fixAllStateSelects($this, $this->_defaults
);
317 if ($this->_priceSetId
) {
318 if (($this->_useForMember
&& !empty($this->_currentMemberships
)) ||
$this->_defaultMemTypeId
) {
319 $selectedCurrentMemTypes = array();
320 foreach ($this->_priceSet
['fields'] as $key => $val) {
321 foreach ($val['options'] as $keys => $values) {
322 $opMemTypeId = CRM_Utils_Array
::value('membership_type_id', $values);
324 in_array($opMemTypeId, $this->_currentMemberships
) &&
325 !in_array($opMemTypeId, $selectedCurrentMemTypes)
327 if ($val['html_type'] == 'CheckBox') {
328 $this->_defaults
["price_{$key}"][$keys] = 1;
331 $this->_defaults
["price_{$key}"] = $keys;
333 $selectedCurrentMemTypes[] = $values['membership_type_id'];
335 elseif (!empty($values['is_default']) &&
337 (!isset($this->_defaults
["price_{$key}"]) ||
338 ($val['html_type'] == 'CheckBox' && !isset($this->_defaults
["price_{$key}"][$keys]))
341 if ($val['html_type'] == 'CheckBox') {
342 $this->_defaults
["price_{$key}"][$keys] = 1;
345 $this->_defaults
["price_{$key}"] = $keys;
352 CRM_Price_BAO_PriceSet
::setDefaultPriceSet($this, $this->_defaults
);
356 if (!empty($this->_paymentProcessors
)) {
357 foreach ($this->_paymentProcessors
as $pid => $value) {
358 if (!empty($value['is_default'])) {
359 $this->_defaults
['payment_processor'] = $pid;
364 return $this->_defaults
;
368 * Function to build the form
373 public function buildQuickForm() {
374 // build profiles first so that we can determine address fields etc
375 // and then show copy address checkbox
376 $this->buildCustom($this->_values
['custom_pre_id'], 'customPre');
377 $this->buildCustom($this->_values
['custom_post_id'], 'customPost');
379 if (!empty($this->_fields
) && !empty($this->_values
['custom_pre_id'])) {
380 $profileAddressFields = array();
381 foreach ($this->_fields
as $key => $value) {
382 CRM_Core_BAO_UFField
::assignAddressField($key, $profileAddressFields, array('uf_group_id' => $this->_values
['custom_pre_id']));
384 $this->set('profileAddressFields', $profileAddressFields);
387 // Build payment processor form
388 if ($this->_ppType
&& empty($_GET['onbehalf'])) {
389 CRM_Core_Payment_ProcessorForm
::buildQuickForm($this);
390 // Return if we are in an ajax callback
391 if ($this->_snippet
) {
396 $config = CRM_Core_Config
::singleton();
398 if ($this->_onbehalf
) {
399 CRM_Contribute_Form_Contribution_OnBehalfOf
::buildQuickForm($this);
400 // Return if we are in an ajax callback
401 if ($this->_snippet
) {
406 $this->applyFilter('__ALL__', 'trim');
407 $this->add('text', "email-{$this->_bltID}",
409 array('size' => 30, 'maxlength' => 60, 'class' => 'email'),
412 $this->addRule("email-{$this->_bltID}", ts('Email is not valid.'), 'email');
414 $onlinePaymentProcessorEnabled = FALSE;
415 if (!empty($this->_paymentProcessors
)) {
416 foreach ($this->_paymentProcessors
as $key => $name) {
417 if($name['billing_mode'] == 1) {
418 $onlinePaymentProcessorEnabled = TRUE;
420 $pps[$key] = $name['name'];
423 if (!empty($this->_values
['is_pay_later'])) {
424 $pps[0] = $this->_values
['pay_later_text'];
427 if (count($pps) > 1) {
428 $this->addRadio('payment_processor', ts('Payment Method'), $pps,
432 elseif (!empty($pps)) {
433 $key = array_keys($pps);
434 $key = array_pop($key);
435 $this->addElement('hidden', 'payment_processor', $key);
437 $this->assign('is_pay_later', $this->_values
['is_pay_later']);
438 $this->assign('pay_later_text', $this->_values
['pay_later_text']);
442 $contactID = $this->getContactID();
443 if($this->getContactID() === '0') {
444 $this->addCidZeroOptions($onlinePaymentProcessorEnabled);
446 //build pledge block.
447 $this->_useForMember
= 0;
448 //don't build membership block when pledge_id is passed
449 if (empty($this->_values
['pledge_id'])) {
450 $this->_separateMembershipPayment
= FALSE;
451 if (in_array('CiviMember', $config->enableComponents
)) {
453 if ($this->_action
& CRM_Core_Action
::PREVIEW
) {
457 if ($this->_priceSetId
&&
458 (CRM_Core_Component
::getComponentID('CiviMember') == CRM_Utils_Array
::value('extends', $this->_priceSet
))
460 $this->_useForMember
= 1;
461 $this->set('useForMember', $this->_useForMember
);
464 $this->_separateMembershipPayment
= CRM_Member_BAO_Membership
::buildMembershipBlock($this,
466 $this->_membershipContactID
,
471 $this->set('separateMembershipPayment', $this->_separateMembershipPayment
);
473 $this->assign('useForMember', $this->_useForMember
);
474 // If we configured price set for contribution page
475 // we are not allow membership signup as well as any
476 // other contribution amount field, CRM-5095
477 if (isset($this->_priceSetId
) && $this->_priceSetId
) {
478 $this->add('hidden', 'priceSetId', $this->_priceSetId
);
479 // build price set form.
480 $this->set('priceSetId', $this->_priceSetId
);
481 CRM_Price_BAO_PriceSet
::buildPriceSet($this);
482 if ($this->_values
['is_monetary'] &&
483 $this->_values
['is_recur'] && empty($this->_values
['pledge_id'])) {
484 self
::buildRecur($this);
488 if ($this->_priceSetId
) {
489 $is_quick_config = CRM_Core_DAO
::getFieldValue('CRM_Price_DAO_PriceSet', $this->_priceSetId
, 'is_quick_config');
490 if ($is_quick_config) {
491 $this->_useForMember
= 0;
492 $this->set('useForMember', $this->_useForMember
);
496 if ($this->_values
['is_for_organization']) {
497 $this->buildOnBehalfOrganization();
500 //we allow premium for pledge during pledge creation only.
501 if (empty($this->_values
['pledge_id'])) {
502 CRM_Contribute_BAO_Premium
::buildPremiumBlock($this, $this->_id
, TRUE);
506 if ($this->_honor_block_is_active
) {
507 $this->assign('honor_block_is_active', TRUE);
509 //build soft-credit section
510 CRM_Contribute_Form_SoftCredit
::buildQuickForm($this);
511 //build honoree profile section
512 CRM_Contact_Form_ProfileContact
::buildQuickForm($this);
516 //don't build pledge block when mid is passed
518 $config = CRM_Core_Config
::singleton();
519 if (in_array('CiviPledge', $config->enableComponents
) && !empty($this->_values
['pledge_block_id'])) {
520 CRM_Pledge_BAO_PledgeBlock
::buildPledgeBlock($this);
524 //to create an cms user
525 if (!$this->_userID
) {
526 $createCMSUser = FALSE;
528 if ($this->_values
['custom_pre_id']) {
529 $profileID = $this->_values
['custom_pre_id'];
530 $createCMSUser = CRM_Core_DAO
::getFieldValue('CRM_Core_DAO_UFGroup', $profileID, 'is_cms_user');
533 if (!$createCMSUser &&
534 $this->_values
['custom_post_id']
536 if (!is_array($this->_values
['custom_post_id'])) {
537 $profileIDs = array($this->_values
['custom_post_id']);
540 $profileIDs = $this->_values
['custom_post_id'];
542 foreach ($profileIDs as $pid) {
543 if (CRM_Core_DAO
::getFieldValue('CRM_Core_DAO_UFGroup', $pid, 'is_cms_user')) {
545 $createCMSUser = TRUE;
551 if ($createCMSUser) {
552 CRM_Core_BAO_CMSUser
::buildForm($this, $profileID, TRUE);
556 if ($pcpSupporter = CRM_PCP_BAO_PCP
::displayName($this->_pcpId
)) {
557 $pcp_supporter_text = ts('This contribution is being made thanks to the effort of <strong>%1</strong>, who supports our campaign.', array(1 => $pcpSupporter));
558 // Only tell people that can also create a PCP if the contribution page has a non-empty value in the "Create Personal Campaign Page link" field.
559 $text = CRM_PCP_BAO_PCP
::getPcpBlockStatus($this->_id
, 'contribute');
561 $pcp_supporter_text .= ts("You can support it as well - once you complete the donation, you will be able to create your own Personal Campaign Page!");
563 $this->assign('pcpSupporterText', $pcp_supporter_text);
565 $prms = array('id' => $this->_pcpId
);
566 CRM_Core_DAO
::commonRetrieve('CRM_PCP_DAO_PCP', $prms, $pcpInfo);
567 if ($pcpInfo['is_honor_roll']) {
568 $this->assign('isHonor', TRUE);
569 $this->add('checkbox', 'pcp_display_in_roll', ts('Show my contribution in the public honor roll'), NULL, NULL,
570 array('onclick' => "showHideByValue('pcp_display_in_roll','','nameID|nickID|personalNoteID','block','radio',false); pcpAnonymous( );")
572 $extraOption = array('onclick' => "return pcpAnonymous( );");
574 $elements[] = &$this->createElement('radio', NULL, '', ts('Include my name and message'), 0, $extraOption);
575 $elements[] = &$this->createElement('radio', NULL, '', ts('List my contribution anonymously'), 1, $extraOption);
576 $this->addGroup($elements, 'pcp_is_anonymous', NULL, ' ');
577 $this->setDefaults(array('pcp_display_in_roll' => 1));
578 $this->setDefaults(array('pcp_is_anonymous' => 1));
580 $this->add('text', 'pcp_roll_nickname', ts('Name'), array('maxlength' => 30));
581 $this->add('textarea', 'pcp_personal_note', ts('Personal Note'), array('style' => 'height: 3em; width: 40em;'));
585 //we have to load confirm contribution button in template
586 //when multiple payment processor as the user
587 //can toggle with payment processor selection
588 $billingModePaymentProcessors = 0;
589 if ( !empty( $this->_paymentProcessors
) ) {
590 foreach ($this->_paymentProcessors
as $key => $values) {
591 if ($values['billing_mode'] == CRM_Core_Payment
::BILLING_MODE_BUTTON
) {
592 $billingModePaymentProcessors++
;
597 if ($billingModePaymentProcessors && count($this->_paymentProcessors
) == $billingModePaymentProcessors) {
598 $allAreBillingModeProcessors = TRUE;
600 $allAreBillingModeProcessors = FALSE;
603 if (!($allAreBillingModeProcessors && !$this->_values
['is_pay_later'])) {
604 $submitButton = array(
606 'name' => CRM_Utils_Array
::value('is_confirm_enabled', $this->_values
) ?
ts('Confirm Contribution') : ts('Contribute'),
607 'spacing' => ' ',
610 // Add submit-once behavior when confirm page disabled
611 if (empty($this->_values
['is_confirm_enabled'])) {
612 $submitButton['js'] = array('onclick' => "return submitOnce(this,'" . $this->_name
. "','" . ts('Processing') . "');");
614 $this->addButtons(array($submitButton));
617 $this->addFormRule(array('CRM_Contribute_Form_Contribution_Main', 'formRule'), $this);
621 * build elements to enable pay on behalf of an organization.
625 function buildOnBehalfOrganization() {
626 if ($this->_membershipContactID
) {
627 $entityBlock = array('contact_id' => $this->_membershipContactID
);
628 CRM_Core_BAO_Location
::getValues($entityBlock, $this->_defaults
);
631 if (!$this->_onBehalfRequired
) {
632 $this->addElement('checkbox', 'is_for_organization',
633 $this->_values
['for_organization'],
634 NULL, array('onclick' => "showOnBehalf( );")
638 $this->assign('is_for_organization', TRUE);
639 $this->assign('urlPath', 'civicrm/contribute/transact');
643 * build elements to collect information for recurring contributions
647 public static function buildRecur(&$form) {
648 $attributes = CRM_Core_DAO
::getAttribute('CRM_Contribute_DAO_ContributionRecur');
649 $className = get_class($form);
651 $form->assign('is_recur_interval', CRM_Utils_Array
::value('is_recur_interval', $form->_values
));
652 $form->assign('is_recur_installments', CRM_Utils_Array
::value('is_recur_installments', $form->_values
));
654 $form->add('checkbox', 'is_recur', ts('I want to contribute this amount'), NULL);
656 if (!empty($form->_values
['is_recur_interval']) ||
$className == 'CRM_Contribute_Form_Contribution') {
657 $form->add('text', 'frequency_interval', ts('Every'), $attributes['frequency_interval']);
658 $form->addRule('frequency_interval', ts('Frequency must be a whole number (EXAMPLE: Every 3 months).'), 'integer');
661 // make sure frequency_interval is submitted as 1 if given no choice to user.
662 $form->add('hidden', 'frequency_interval', 1);
665 $frUnits = CRM_Utils_Array
::value('recur_frequency_unit', $form->_values
);
666 if (empty($frUnits) &&
667 $className == 'CRM_Contribute_Form_Contribution'
669 $frUnits = implode(CRM_Core_DAO
::VALUE_SEPARATOR
,
670 CRM_Core_OptionGroup
::values('recur_frequency_units')
674 $unitVals = explode(CRM_Core_DAO
::VALUE_SEPARATOR
, $frUnits);
676 // CRM 10860, display text instead of a dropdown if there's only 1 frequency unit
677 if(sizeof($unitVals) == 1) {
678 $form->assign('one_frequency_unit', true);
679 $unit = $unitVals[0];
680 $form->add('hidden', 'frequency_unit', $unit);
681 if (!empty($form->_values
['is_recur_interval']) ||
$className == 'CRM_Contribute_Form_Contribution') {
684 $form->assign('frequency_unit', $unit);
686 $form->assign('one_frequency_unit', false);
688 $frequencyUnits = CRM_Core_OptionGroup
::values('recur_frequency_units');
689 foreach ($unitVals as $key => $val) {
690 if (array_key_exists($val, $frequencyUnits)) {
691 $units[$val] = $frequencyUnits[$val];
692 if (!empty($form->_values
['is_recur_interval']) ||
$className == 'CRM_Contribute_Form_Contribution') {
693 $units[$val] = "{$frequencyUnits[$val]}(s)";
697 $frequencyUnit = &$form->add('select', 'frequency_unit', NULL, $units);
701 // FIXME: Ideally we should freeze select box if there is only
702 // one option but looks there is some problem /w QF freeze.
703 //if ( count( $units ) == 1 ) {
704 //$frequencyUnit->freeze( );
707 $form->add('text', 'installments', ts('installments'),
708 $attributes['installments']
710 $form->addRule('installments', ts('Number of installments must be a whole number.'), 'integer');
716 * @param array $fields the input form values
717 * @param array $files the uploaded files if any
720 * @internal param array $options additional user data
722 * @return true if no errors, else array of errors
726 static function formRule($fields, $files, $self) {
728 $amount = self
::computeAmount($fields, $self);
730 if ((!empty($fields['selectMembership']) &&
731 $fields['selectMembership'] != 'no_thanks'
733 (!empty($fields['priceSetId']) &&
737 $lifeMember = CRM_Member_BAO_Membership
::getAllContactMembership($self->_userID
, FALSE, TRUE);
739 $membershipOrgDetails = CRM_Member_BAO_MembershipType
::getMembershipTypeOrganization();
741 $unallowedOrgs = array();
742 foreach (array_keys($lifeMember) as $memTypeId) {
743 $unallowedOrgs[] = $membershipOrgDetails[$memTypeId];
747 //check for atleast one pricefields should be selected
748 if (!empty($fields['priceSetId'])) {
749 $priceField = new CRM_Price_DAO_PriceField();
750 $priceField->price_set_id
= $fields['priceSetId'];
751 $priceField->orderBy('weight');
755 $membershipIsActive = TRUE;
756 $previousId = $otherAmount = FALSE;
757 while ($priceField->fetch()) {
759 if ($self->_quickConfig
&& ($priceField->name
== 'contribution_amount' ||
$priceField->name
== 'membership_amount')) {
760 $previousId = $priceField->id
;
761 if ($priceField->name
== 'membership_amount' && !$priceField->is_active
) {
762 $membershipIsActive = FALSE;
765 if ($priceField->name
== 'other_amount') {
766 if ($self->_quickConfig
&& empty($fields["price_{$priceField->id}"]) &&
767 array_key_exists("price_{$previousId}", $fields) && isset($fields["price_{$previousId}"]) && $self->_values
['fee'][$previousId]['name'] == 'contribution_amount' && empty($fields["price_{$previousId}"])) {
768 $otherAmount = $priceField->id
;
770 elseif (!empty($fields["price_{$priceField->id}"])) {
771 $otherAmountVal = $fields["price_{$priceField->id}"];
772 $min = CRM_Utils_Array
::value('min_amount', $self->_values
);
773 $max = CRM_Utils_Array
::value('max_amount', $self->_values
);
774 if ($min && $otherAmountVal < $min) {
775 $errors["price_{$priceField->id}"] = ts('Contribution amount must be at least %1',
779 if ($max && $otherAmountVal > $max) {
780 $errors["price_{$priceField->id}"] = ts('Contribution amount cannot be more than %1.',
786 if (!empty($fields["price_{$priceField->id}"]) ||
($previousId == $priceField->id
&& isset($fields["price_{$previousId}"])
787 && empty($fields["price_{$previousId}"]))) {
788 $check[] = $priceField->id
;
793 if ($membershipIsActive && !$self->_membershipBlock
['is_required']
794 && $self->_values
['amount_block_is_active']) {
795 $membershipFieldId = $contributionFieldId = $errorKey = $otherFieldId = NULL;
796 foreach ($self->_values
['fee'] as $fieldKey => $fieldValue) {
797 // if 'No thank you' membership is selected then set $membershipFieldId
798 if ($fieldValue['name'] == 'membership_amount' && CRM_Utils_Array
::value('price_' . $fieldKey, $fields) == 0) {
799 $membershipFieldId = $fieldKey;
801 elseif ($membershipFieldId) {
802 if ($fieldValue['name'] == 'other_amount') {
803 $otherFieldId = $fieldKey;
805 elseif ($fieldValue['name'] == 'contribution_amount') {
806 $contributionFieldId = $fieldKey;
809 if (!$errorKey || CRM_Utils_Array
::value('price_' . $contributionFieldId, $fields) == '0') {
810 $errorKey = $fieldKey;
814 // $membershipFieldId is set and additional amount is 'No thank you' or NULL then throw error
815 if ($membershipFieldId && !(CRM_Utils_Array
::value('price_' . $contributionFieldId, $fields, -1) > 0) && empty($fields['price_' . $otherFieldId])) {
816 $errors["price_{$errorKey}"] = ts('Additional Contribution is required.');
820 if ($self->_useForMember
== 1 && $membershipIsActive) {
821 $errors['_qf_default'] = ts('Select at least one option from Membership Type(s).');
824 $errors['_qf_default'] = ts('Select at least one option from Contribution(s).');
827 if($otherAmount && !empty($check)) {
828 $errors["price_{$otherAmount}"] = ts('Amount is required field.');
831 if ($self->_useForMember
== 1 && !empty($check) && $membershipIsActive) {
832 $priceFieldIDS = array();
833 $priceFieldMemTypes = array();
835 foreach ($self->_priceSet
['fields'] as $priceId => $value) {
836 if (!empty($fields['price_' . $priceId]) ||
($self->_quickConfig
&& $value['name'] == 'membership_amount' && empty($self->_membershipBlock
['is_required']))) {
837 if (!empty($fields['price_' . $priceId]) && is_array($fields['price_' . $priceId])) {
838 foreach ($fields['price_' . $priceId] as $priceFldVal => $isSet) {
840 $priceFieldIDS[] = $priceFldVal;
844 elseif (!$value['is_enter_qty'] && !empty($fields['price_' . $priceId])) {
845 // The check for {!$value['is_enter_qty']} is done since, quantity fields allow entering
846 // quantity. And the quantity can't be conisdered as civicrm_price_field_value.id, CRM-9577
847 $priceFieldIDS[] = $fields['price_' . $priceId];
850 if (!empty($value['options'])) {
851 foreach ($value['options'] as $val) {
852 if (!empty($val['membership_type_id'])) {
853 $priceFieldMemTypes[] = $val['membership_type_id'];
860 if (!empty($lifeMember)) {
861 foreach ($priceFieldIDS as $priceFieldId) {
862 if (($id = CRM_Core_DAO
::getFieldValue('CRM_Price_DAO_PriceFieldValue', $priceFieldId, 'membership_type_id')) &&
863 in_array($membershipOrgDetails[$id], $unallowedOrgs)
865 $errors['_qf_default'] = ts('You already have a lifetime membership and cannot select a membership with a shorter term.');
871 if (!empty($priceFieldIDS)) {
872 $ids = implode(',', $priceFieldIDS);
874 $priceFieldIDS['id'] = $fields['priceSetId'];
875 $self->set('memberPriceFieldIDS', $priceFieldIDS);
876 $count = CRM_Price_BAO_PriceSet
::getMembershipCount($ids);
877 foreach ($count as $id => $occurance) {
878 if ($occurance > 1) {
879 $errors['_qf_default'] = ts('You have selected multiple memberships for the same organization or entity. Please review your selections and choose only one membership per entity. Contact the site administrator if you need assistance.');
884 if (empty($priceFieldMemTypes)) {
885 $errors['_qf_default'] = ts('Please select at least one membership option.');
889 CRM_Price_BAO_PriceSet
::processAmount($self->_values
['fee'],
893 if ($fields['amount'] < 0) {
894 $errors['_qf_default'] = ts('Contribution can not be less than zero. Please select the options accordingly');
896 $amount = $fields['amount'];
899 if (isset($fields['selectProduct']) &&
900 $fields['selectProduct'] != 'no_thanks') {
901 $productDAO = new CRM_Contribute_DAO_Product();
902 $productDAO->id
= $fields['selectProduct'];
903 $productDAO->find(TRUE);
904 $min_amount = $productDAO->min_contribution
;
906 if ($amount < $min_amount) {
907 $errors['selectProduct'] = ts('The premium you have selected requires a minimum contribution of %1', array(1 => CRM_Utils_Money
::format($min_amount)));
908 CRM_Core_Session
::setStatus($errors['selectProduct']);
912 if (!empty($fields['is_recur'])) {
913 if ($fields['frequency_interval'] <= 0) {
914 $errors['frequency_interval'] = ts('Please enter a number for how often you want to make this recurring contribution (EXAMPLE: Every 3 months).');
916 if ($fields['frequency_unit'] == '0') {
917 $errors['frequency_unit'] = ts('Please select a period (e.g. months, years ...) for how often you want to make this recurring contribution (EXAMPLE: Every 3 MONTHS).');
921 if (!empty($fields['is_recur']) &&
922 CRM_Utils_Array
::value('payment_processor', $fields) == 0) {
923 $errors['_qf_default'] = ts('You cannot set up a recurring contribution if you are not paying online by credit card.');
926 if (!empty($fields['is_for_organization']) &&
927 !property_exists($self, 'organizationName')
930 if (empty($fields['onbehalf']['organization_name'])) {
931 if (!empty($fields['org_option']) && !$fields['onbehalfof_id']) {
932 $errors['organization_id'] = ts('Please select an organization or enter a new one.');
934 elseif (empty($fields['org_option'])) {
935 $errors['onbehalf']['organization_name'] = ts('Please enter the organization name.');
939 foreach ($fields['onbehalf'] as $key => $value) {
940 if (strstr($key, 'email')) {
941 $emailLocType = explode('-', $key);
944 if (empty($fields['onbehalf']["email-{$emailLocType[1]}"])) {
945 $errors['onbehalf']["email-{$emailLocType[1]}"] = ts('Organization email is required.');
949 // validate PCP fields - if not anonymous, we need a nick name value
950 if ($self->_pcpId
&& !empty($fields['pcp_display_in_roll']) &&
951 (CRM_Utils_Array
::value('pcp_is_anonymous', $fields) == 0) &&
952 CRM_Utils_Array
::value('pcp_roll_nickname', $fields) == ''
954 $errors['pcp_roll_nickname'] = ts('Please enter a name to include in the Honor Roll, or select \'contribute anonymously\'.');
957 // return if this is express mode
958 $config = CRM_Core_Config
::singleton();
959 if ($self->_paymentProcessor
&&
960 $self->_paymentProcessor
['billing_mode'] & CRM_Core_Payment
::BILLING_MODE_BUTTON
962 if (!empty($fields[$self->_expressButtonName
. '_x']) ||
!empty($fields[$self->_expressButtonName
. '_y']) ||
963 CRM_Utils_Array
::value($self->_expressButtonName
, $fields)
969 //validate the pledge fields.
970 if (!empty($self->_values
['pledge_block_id'])) {
971 //validation for pledge payment.
972 if (!empty($self->_values
['pledge_id'])) {
973 if (empty($fields['pledge_amount'])) {
974 $errors['pledge_amount'] = ts('At least one payment option needs to be checked.');
977 elseif (!empty($fields['is_pledge'])) {
978 if (CRM_Utils_Rule
::positiveInteger(CRM_Utils_Array
::value('pledge_installments', $fields)) == FALSE) {
979 $errors['pledge_installments'] = ts('Please enter a valid number of pledge installments.');
982 if (CRM_Utils_Array
::value('pledge_installments', $fields) == NULL) {
983 $errors['pledge_installments'] = ts('Pledge Installments is required field.');
985 elseif (CRM_Utils_array
::value('pledge_installments', $fields) == 1) {
986 $errors['pledge_installments'] = ts('Pledges consist of multiple scheduled payments. Select one-time contribution if you want to make your gift in a single payment.');
988 elseif (CRM_Utils_array
::value('pledge_installments', $fields) == 0) {
989 $errors['pledge_installments'] = ts('Pledge Installments field must be > 1.');
993 //validation for Pledge Frequency Interval.
994 if (CRM_Utils_Rule
::positiveInteger(CRM_Utils_Array
::value('pledge_frequency_interval', $fields)) == FALSE) {
995 $errors['pledge_frequency_interval'] = ts('Please enter a valid Pledge Frequency Interval.');
998 if (CRM_Utils_Array
::value('pledge_frequency_interval', $fields) == NULL) {
999 $errors['pledge_frequency_interval'] = ts('Pledge Frequency Interval. is required field.');
1001 elseif (CRM_Utils_array
::value('pledge_frequency_interval', $fields) == 0) {
1002 $errors['pledge_frequency_interval'] = ts('Pledge frequency interval field must be > 0');
1008 // also return if paylater mode
1009 if (CRM_Utils_Array
::value('payment_processor', $fields) == 0) {
1010 return empty($errors) ?
TRUE : $errors;
1013 // if the user has chosen a free membership or the amount is less than zero
1014 // i.e. we skip calling the payment processor and hence dont need credit card
1016 if ((float) $amount <= 0.0) {
1020 if (!empty($self->_paymentFields
)) {
1021 CRM_Core_Form
::validateMandatoryFields($self->_paymentFields
, $fields, $errors);
1023 CRM_Core_Payment_Form
::validateCreditCard($fields, $errors);
1025 foreach (CRM_Contact_BAO_Contact
::$_greetingTypes as $greeting) {
1026 if ($greetingType = CRM_Utils_Array
::value($greeting, $fields)) {
1027 $customizedValue = CRM_Core_OptionGroup
::getValue($greeting, 'Customized', 'name');
1028 if ($customizedValue == $greetingType && empty($fielse[$greeting . '_custom'])) {
1029 $errors[$greeting . '_custom'] = ts('Custom %1 is a required field if %1 is of type Customized.',
1030 array(1 => ucwords(str_replace('_', " ", $greeting)))
1036 return empty($errors) ?
TRUE : $errors;
1043 * @return int|mixed|null|string
1045 public static function computeAmount(&$params, &$form) {
1048 // first clean up the other amount field if present
1049 if (isset($params['amount_other'])) {
1050 $params['amount_other'] = CRM_Utils_Rule
::cleanMoney($params['amount_other']);
1053 if (CRM_Utils_Array
::value('amount', $params) == 'amount_other_radio' ||
!empty($params['amount_other'])) {
1054 $amount = $params['amount_other'];
1056 elseif (!empty($params['pledge_amount'])) {
1058 foreach ($params['pledge_amount'] as $paymentId => $dontCare) {
1059 $amount +
= CRM_Core_DAO
::getFieldValue('CRM_Pledge_DAO_PledgePayment', $paymentId, 'scheduled_amount');
1063 if (!empty($form->_values
['amount'])) {
1064 $amountID = CRM_Utils_Array
::value('amount', $params);
1067 $params['amount_level'] = CRM_Utils_Array
::value('label', $form->_values
[$amountID]);
1068 $amount = CRM_Utils_Array
::value('value', $form->_values
[$amountID]);
1076 * Function to process the form
1082 public function postProcess() {
1083 $config = CRM_Core_Config
::singleton();
1085 // we first reset the confirm page so it accepts new values
1086 $this->controller
->resetPage('Confirm');
1088 // get the submitted form values.
1089 $params = $this->controller
->exportValues($this->_name
);
1091 if (!empty($params['priceSetId'])) {
1092 $is_quick_config = CRM_Core_DAO
::getFieldValue('CRM_Price_DAO_PriceSet', $this->_priceSetId
, 'is_quick_config');
1093 if ($is_quick_config) {
1094 $priceField = new CRM_Price_DAO_PriceField();
1095 $priceField->price_set_id
= $params['priceSetId'];
1096 $priceField->orderBy('weight');
1097 $priceField->find();
1099 $priceOptions = array();
1100 while ($priceField->fetch()) {
1101 CRM_Price_BAO_PriceFieldValue
::getValues($priceField->id
, $priceOptions);
1102 if ($selectedPriceOptionID = CRM_Utils_Array
::value("price_{$priceField->id}", $params)) {
1103 switch ($priceField->name
) {
1104 case 'membership_amount':
1105 $this->_params
['selectMembership'] = $params['selectMembership'] = CRM_Utils_Array
::value('membership_type_id', $priceOptions[$selectedPriceOptionID]);
1106 $this->set('selectMembership', $params['selectMembership']);
1107 if (CRM_Utils_Array
::value('is_separate_payment', $this->_membershipBlock
) == 0) {
1108 $this->_values
['amount'] = CRM_Utils_Array
::value('amount', $priceOptions[$selectedPriceOptionID]);
1112 case 'contribution_amount':
1113 $params['amount'] = $selectedPriceOptionID;
1114 $this->_values
['amount'] = CRM_Utils_Array
::value('amount', $priceOptions[$selectedPriceOptionID]);
1115 $this->_values
[$selectedPriceOptionID]['value'] = CRM_Utils_Array
::value('amount', $priceOptions[$selectedPriceOptionID]);
1116 $this->_values
[$selectedPriceOptionID]['label'] = CRM_Utils_Array
::value('label', $priceOptions[$selectedPriceOptionID]);
1117 $this->_values
[$selectedPriceOptionID]['amount_id'] = CRM_Utils_Array
::value('id', $priceOptions[$selectedPriceOptionID]);
1118 $this->_values
[$selectedPriceOptionID]['weight'] = CRM_Utils_Array
::value('weight', $priceOptions[$selectedPriceOptionID]);
1121 case 'other_amount':
1122 $params['amount_other'] = $selectedPriceOptionID;
1130 if (($this->_values
['is_pay_later'] &&
1131 empty($this->_paymentProcessor
) &&
1132 !array_key_exists('hidden_processor', $params)) ||
1133 CRM_Utils_Array
::value('payment_processor', $params) == 0) {
1134 $params['is_pay_later'] = 1;
1137 $params['is_pay_later'] = 0;
1140 $this->set('is_pay_later', $params['is_pay_later']);
1141 // assign pay later stuff
1142 $this->_params
['is_pay_later'] = CRM_Utils_Array
::value('is_pay_later', $params, FALSE);
1143 $this->assign('is_pay_later', $params['is_pay_later']);
1144 if ($params['is_pay_later']) {
1145 $this->assign('pay_later_text', $this->_values
['pay_later_text']);
1146 $this->assign('pay_later_receipt', $this->_values
['pay_later_receipt']);
1149 //carry campaign from profile.
1150 if (array_key_exists('contribution_campaign_id', $params)) {
1151 $params['campaign_id'] = $params['contribution_campaign_id'];
1154 if (!empty($params['onbehalfof_id'])) {
1155 $params['organization_id'] = $params['onbehalfof_id'];
1158 $params['currencyID'] = $config->defaultCurrency
;
1159 // from here on down, $params['amount'] holds a monetary value (or null) rather than an option ID
1160 $params['amount'] = self
::computeAmount($params, $this);
1161 $params['separate_amount'] = $params['amount'];
1163 if (!empty($params['selectMembership'])) {
1164 if (!empty($this->_membershipTypeValues
)) {
1165 $membershipTypeValues = $this->_membershipTypeValues
[$params['selectMembership']];
1168 $membershipTypeValues = CRM_Member_BAO_Membership
::buildMembershipTypeValues($this,
1169 $params['selectMembership']
1172 $memFee = $membershipTypeValues['minimum_fee'];
1173 if (!$params['amount'] && !$this->_separateMembershipPayment
) {
1174 $params['amount'] = $memFee ?
$memFee : 0;
1178 //If the membership & contribution is used in contribution page & not seperate payment
1179 $fieldId = $memPresent = $membershipLabel = $fieldOption = $is_quick_config = NULL;
1180 $proceFieldAmount = 0;
1181 if (property_exists($this, '_separateMembershipPayment') && $this->_separateMembershipPayment
== 0) {
1182 $is_quick_config = CRM_Core_DAO
::getFieldValue('CRM_Price_DAO_PriceSet', $this->_priceSetId
, 'is_quick_config');
1183 if ($is_quick_config) {
1184 foreach ($this->_priceSet
['fields'] as $fieldKey => $fieldVal) {
1185 if ($fieldVal['name'] == 'membership_amount' && !empty($params['price_' . $fieldKey ])) {
1186 $fieldId = $fieldVal['id'];
1187 $fieldOption = $params['price_' . $fieldId];
1188 $proceFieldAmount +
= $fieldVal['options'][$this->_submitValues
['price_' . $fieldId]]['amount'];
1192 if (!empty($params['price_' . $fieldKey]) && $memPresent && ($fieldVal['name'] == 'other_amount' ||
$fieldVal['name'] == 'contribution_amount')) {
1193 $fieldId = $fieldVal['id'];
1194 if ($fieldVal['name'] == 'other_amount') {
1195 $proceFieldAmount +
= $this->_submitValues
['price_' . $fieldId];
1197 elseif ($fieldVal['name'] == 'contribution_amount' && $this->_submitValues
['price_' . $fieldId] > 0) {
1198 $proceFieldAmount +
= $fieldVal['options'][$this->_submitValues
['price_' . $fieldId]]['amount'];
1200 unset($params['price_' . $fieldId]);
1208 if (!isset($params['amount_other'])) {
1209 $this->set('amount_level', CRM_Utils_Array
::value('amount_level', $params));
1212 if ($priceSetId = CRM_Utils_Array
::value('priceSetId', $params)) {
1213 $lineItem = array();
1214 $is_quick_config = CRM_Core_DAO
::getFieldValue('CRM_Price_DAO_PriceSet', $priceSetId, 'is_quick_config' );
1215 if ( $is_quick_config ) {
1216 foreach ( $this->_values
['fee'] as $key => & $val ) {
1217 if ( $val['name'] == 'other_amount' && $val['html_type'] == 'Text' && array_key_exists( 'price_'.$key, $params ) && $params['price_'.$key] != 0 ) {
1218 foreach ( $val['options'] as $optionKey => & $options ) {
1219 $options['amount'] = CRM_Utils_Array
::value( 'price_'.$key, $params );
1222 $params['price_'.$key] = 1;
1229 if ($this->_membershipBlock
) {
1230 $component = 'membership';
1232 CRM_Price_BAO_PriceSet
::processAmount($this->_values
['fee'], $params, $lineItem[$priceSetId], $component);
1234 if ($proceFieldAmount) {
1235 $lineItem[$params['priceSetId']][$fieldOption]['line_total'] = $proceFieldAmount;
1236 $lineItem[$params['priceSetId']][$fieldOption]['unit_price'] = $proceFieldAmount;
1237 if (!$this->_membershipBlock
['is_separate_payment']) {
1238 $params['amount'] = $proceFieldAmount; //require when separate membership not used
1241 $this->set('lineItem', $lineItem);
1244 if ($this->_membershipBlock
['is_separate_payment'] && !empty($params['separate_amount'])) {
1245 $this->set('amount', $params['separate_amount']);
1247 $this->set('amount', $params['amount']);
1250 // generate and set an invoiceID for this transaction
1251 $invoiceID = md5(uniqid(rand(), TRUE));
1252 $this->set('invoiceID', $invoiceID);
1254 // required only if is_monetary and valid postive amount
1255 if ($this->_values
['is_monetary'] &&
1256 is_array($this->_paymentProcessor
) &&
1257 ((float ) $params['amount'] > 0.0 ||
$memFee > 0.0)
1260 // default mode is direct
1261 $this->set('contributeMode', 'direct');
1263 if ($this->_paymentProcessor
&&
1264 $this->_paymentProcessor
['billing_mode'] & CRM_Core_Payment
::BILLING_MODE_BUTTON
1266 //get the button name
1267 $buttonName = $this->controller
->getButtonName();
1268 if (in_array($buttonName,
1269 array($this->_expressButtonName
, $this->_expressButtonName
. '_x', $this->_expressButtonName
. '_y')
1270 ) && empty($params['is_pay_later'])) {
1271 $this->set('contributeMode', 'express');
1273 $donateURL = CRM_Utils_System
::url('civicrm/contribute', '_qf_Contribute_display=1');
1274 $params['cancelURL'] = CRM_Utils_System
::url('civicrm/contribute/transact', "_qf_Main_display=1&qfKey={$params['qfKey']}", TRUE, NULL, FALSE);
1275 $params['returnURL'] = CRM_Utils_System
::url('civicrm/contribute/transact', "_qf_Confirm_display=1&rfp=1&qfKey={$params['qfKey']}", TRUE, NULL, FALSE);
1276 $params['invoiceID'] = $invoiceID;
1278 //default action is Sale
1279 $params['payment_action'] = 'Sale';
1281 $payment = CRM_Core_Payment
::singleton($this->_mode
, $this->_paymentProcessor
, $this);
1282 $token = $payment->setExpressCheckout($params);
1283 if (is_a($token, 'CRM_Core_Error')) {
1284 CRM_Core_Error
::displaySessionError($token);
1285 CRM_Utils_System
::redirect($params['cancelURL']);
1288 $this->set('token', $token);
1290 $paymentURL = $this->_paymentProcessor
['url_site'] . "/cgi-bin/webscr?cmd=_express-checkout&token=$token";
1291 CRM_Utils_System
::redirect($paymentURL);
1294 elseif ($this->_paymentProcessor
&&
1295 $this->_paymentProcessor
['billing_mode'] & CRM_Core_Payment
::BILLING_MODE_NOTIFY
1297 $this->set('contributeMode', 'notify');
1301 // should we skip the confirm page?
1302 if (empty($this->_values
['is_confirm_enabled'])) {
1303 // call the post process hook for the main page before we switch to confirm
1304 $this->postProcessHook();
1306 // build the confirm page
1307 $confirmForm = &$this->controller
->_pages
['Confirm'];
1308 $confirmForm->preProcess();
1309 $confirmForm->buildQuickForm();
1311 // the confirmation page is valid
1312 $data = &$this->controller
->container();
1313 $data['valid']['Confirm'] = 1;
1315 // confirm the contribution
1316 // mainProcess calls the hook also
1317 $confirmForm->mainProcess();
1318 $qfKey = $this->controller
->_key
;
1320 // redirect to thank you page
1321 CRM_Utils_System
::redirect(CRM_Utils_System
::url('civicrm/contribute/transact', "_qf_ThankYou_display=1&qfKey=$qfKey", TRUE, NULL, FALSE));
1326 * Handle Payment Processor switching
1327 * For contribution and event registration forms
1329 static function preProcessPaymentOptions(&$form, $noFees = FALSE) {
1330 $form->_snippet
= CRM_Utils_Array
::value('snippet', $_GET);
1332 $form->_paymentProcessors
= $noFees ?
array() : $form->get('paymentProcessors');
1333 $form->_ppType
= NULL;
1334 if ($form->_paymentProcessors
) {
1335 // Fetch type during ajax request
1336 if (isset($_GET['type']) && $form->_snippet
) {
1337 $form->_ppType
= $_GET['type'];
1339 // Remember type during form post
1340 elseif (!empty($form->_submitValues
)) {
1341 $form->_ppType
= CRM_Utils_Array
::value('payment_processor', $form->_submitValues
);
1342 $form->_paymentProcessor
= CRM_Utils_Array
::value($form->_ppType
, $form->_paymentProcessors
);
1343 $form->set('type', $form->_ppType
);
1344 $form->set('mode', $form->_mode
);
1345 $form->set('paymentProcessor', $form->_paymentProcessor
);
1347 // Set default payment processor
1349 foreach ($form->_paymentProcessors
as $values) {
1350 if (!empty($values['is_default']) ||
count($form->_paymentProcessors
) == 1) {
1351 $form->_ppType
= $values['id'];
1356 if ($form->_ppType
) {
1357 CRM_Core_Payment_ProcessorForm
::preProcess($form);
1360 //get payPal express id and make it available to template
1361 foreach ($form->_paymentProcessors
as $ppId => $values) {
1362 $payPalExpressId = ($values['payment_processor_type'] == 'PayPal_Express') ?
$values['id'] : 0;
1363 $form->assign('payPalExpressId', $payPalExpressId);
1364 if ($payPalExpressId) {
1368 if (!$form->_snippet
) {
1369 // Add JS to show icons for the accepted credit cards
1370 $creditCardTypes = CRM_Core_Payment_Form
::getCreditCardCSSNames();
1371 CRM_Core_Resources
::singleton()
1372 ->addScriptFile('civicrm', 'templates/CRM/Core/BillingBlock.js', 10)
1373 // workaround for CRM-13634
1374 // ->addSetting(array('config' => array('creditCardTypes' => $creditCardTypes)));
1375 ->addScript('CRM.config.creditCardTypes = ' . json_encode($creditCardTypes) . ';');
1378 $form->assign('ppType', $form->_ppType
);