Merge pull request #10625 from mickadoo/CRM-20833-update-api4-entity-namespace
[civicrm-core.git] / CRM / Financial / Form / Payment.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 *
30 * @package CRM
31 * @copyright CiviCRM LLC (c) 2004-2017
32 */
33 class CRM_Financial_Form_Payment extends CRM_Core_Form {
34
35 /**
36 * @var int
37 */
38 protected $_paymentProcessorID;
39 protected $currency;
40
41 public $_values = array();
42
43 /**
44 * @var array
45 */
46 public $_paymentProcessor;
47
48 /**
49 * @var bool
50 */
51 public $isBackOffice = FALSE;
52
53 /**
54 * Set variables up before form is built.
55 */
56 public function preProcess() {
57 parent::preProcess();
58
59 $this->_values['custom_pre_id'] = CRM_Utils_Request::retrieve('pre_profile_id', 'Integer', $this);
60
61 $this->_paymentProcessorID = CRM_Utils_Request::retrieve('processor_id', 'Integer', CRM_Core_DAO::$_nullObject,
62 TRUE);
63 $this->currency = CRM_Utils_Request::retrieve('currency', 'String', CRM_Core_DAO::$_nullObject,
64 TRUE);
65
66 $this->paymentInstrumentID = CRM_Utils_Request::retrieve('payment_instrument_id', 'Integer');
67 $this->isBackOffice = CRM_Utils_Request::retrieve('is_back_office', 'Integer');
68
69 $this->assignBillingType();
70
71 $this->_paymentProcessor = CRM_Financial_BAO_PaymentProcessor::getPayment($this->_paymentProcessorID);
72
73 CRM_Core_Payment_ProcessorForm::preProcess($this);
74
75 self::addCreditCardJs($this->_paymentProcessorID);
76
77 $this->assign('paymentProcessorID', $this->_paymentProcessorID);
78 $this->assign('currency', $this->currency);
79
80 $this->assign('suppressForm', TRUE);
81 $this->controller->_generateQFKey = FALSE;
82 }
83
84 /**
85 * @return string
86 */
87 public function getCurrency() {
88 return $this->currency;
89 }
90
91 /**
92 * Build quickForm.
93 */
94 public function buildQuickForm() {
95 CRM_Core_Payment_ProcessorForm::buildQuickForm($this);
96 }
97
98 /**
99 * Set default values for the form.
100 */
101 public function setDefaultValues() {
102 $contactID = $this->getContactID();
103 CRM_Core_Payment_Form::setDefaultValues($this, $contactID);
104 return $this->_defaults;
105 }
106
107 /**
108 * Add JS to show icons for the accepted credit cards.
109 *
110 * @param int $paymentProcessorID
111 */
112 public static function addCreditCardJs($paymentProcessorID = NULL) {
113 $creditCards = CRM_Financial_BAO_PaymentProcessor::getCreditCards($paymentProcessorID);
114 $creditCardTypes = CRM_Core_Payment_Form::getCreditCardCSSNames($creditCards);
115 CRM_Core_Resources::singleton()
116 // CRM-20516: add BillingBlock script on billing-block region
117 // to support this feature in payment form snippet too.
118 ->addScriptFile('civicrm', 'templates/CRM/Core/BillingBlock.js', 10, 'billing-block', FALSE)
119 // workaround for CRM-13634
120 // ->addSetting(array('config' => array('creditCardTypes' => $creditCardTypes)));
121 ->addScript('CRM.config.creditCardTypes = ' . json_encode($creditCardTypes) . ';', '-9999', 'billing-block');
122 }
123
124 }