Integrate Payment Selection Page
Last updated: May 14th, 10:36am
    
Important: PayPal Plus for Mexico is not available for new integrations. PayPal provides this documentation to support existing integrations.
For PayPal Plus for Brazil, see the Brazilian integration guide.
To collect payment information, you must integrate a payment selection page by using an embedded iFrame or mini browser.
Embed an iFrame
You can display the payment selection page in an iFrame where buyers enter their credit card information. To render it, you must complete the following tasks.
- 
        Include the JavaScript library on your checkout page using the following script: 1<script src="https://www.paypalobjects.com/webstatic/ppplusdcc/ppplusdcc.min.js" type="text/javascript">2</script>
- 
        Define a placeholder DIV on your checkout page for the payment selection page: 1<div id="ppplus">2</div>
- 
        Render the payment selection page using the following script. Include the approval_urlreturned from the previously issued request to create a payment.1<script type="application/javascript">2var ppp = PAYPAL.apps.PPP({3"approvalUrl": "'.$approval_url.'",4 "placeholder": "ppplus",5 "mode": "sandbox",});6</script>
- 
        Create an external Continue button by setting the following parameters in the script to render the payment selection page: - disableContinue: "continueButton"
- enableContinue: "continueButton"
 When the external Continue button is pressed, a response object that contains the payer’s ID, the rememberedCardstoken, and the installment selection is posted to the checkout page if execution of payment can proceed. If payment execution cannot proceed, an error is displayed.Add the following script to your external Continue button: 1<button>2type="submit"3id="continueButton"4onclick="ppp.doContinue(); return false;"> Checkout5</button>The following sample client-side JavaScript handles the response object that is posted when the external Continue button is pressed. 1// Register postMessage Listener for the iframe.2if (window.addEventListener) {3window.addEventListener("message", messageListener, false);4log("addEventListener successful", "debug");5} else if (window.attachEvent) {6window.attachEvent("onmessage", messageListener);7log("attachEvent successful", "debug");8} else {9log("Could not attach message listener", "debug");10throw new Error("Can't attach message listener");11}1213function messageListener(event) {14 try {15 //this is how we extract the message from the incoming events, data format should look like {"action":"inlineCheckout","checkoutSession":"error","result":"missing data in the credit card form"}16 var data = JSON.parse(event.data);17 //insert logic here to handle success events or errors, if any18 }19 } catch (exc) {}20}
Note: To personalize the iFrame, merchants can adjust several of the CSS attributes. For more information, see Custom Style for Payment Wall.
Display mini browser
You can display the payment selection page in a mini browser where buyers enter their credit card information. A button is required to open the mini browser without the browser’s pop-up blocker blocking it. To render it, you must complete the following tasks.
- 
        Use this script to include the JavaScript library on your checkout page. 1<script src="https://www.paypalobjects.com/webstatic/ppplusdcc/ppplusdcc.min.js" type="text/javascript"></script>
- 
        Render the payment selection page using the following script and example button. Include the ‘approval_url’ returned from the previously issued request to create a payment. 1<script language="JavaScript">2function initiateCheckout() {3var ppp = PAYPAL.apps.PPP({4 "approvalUrl": "'.$approval_url.'",5 "placeholder": "ppplus",6 "mode": "sandbox",});7}8</script>9<button type="submit" id="miniBrowserInitiateCheckout"10class="btn btn-lg btn-primary btn-block"11onclick=" initiateCheckout(); return false;">12Checkout13</button>
Payment selection page components
The components in the previous examples enable integration of and later launch the payment selection page.
PayPal Plus JavaScript library
Loading the ppplusdcc.min.js JavaScript library creates a new object called PAYPAL.apps.PPP. The PPP object defines the API.
PayPal Plus API
To use the PayPal Plus API, send the PPP object with the required parameters in your request.
| Parameter | Type | Description | 
|---|---|---|
| approvalUrl | string | (Required) The approvalUrlreturned by the create payment call. | 
| payerEmail | string | (Required) Email address of the payer providing payment information for checkout. | 
| payerFirstName | string | (Required) First name of the payer providing payment information for checkout. This name must match the name on the credit card. | 
| payerLastName | string | (Required) Last name of the payer providing payment information for checkout. This name must match the name on the credit card. | 
| payerPhone | string | (Required for seller protection) Phone number of the payer providing payment information for checkout. | 
| payerTaxId | string | Leave blank. | 
| placeholder | string | (Required) The ID of a DOM object where the payment selection page is embedded in your checkout page. The payment selection page adapts to the width of the specified object. If miniBrowseristrue, then this can be set to any non-empty string. | 
| country | string | Country where the PayPal Plus service is deployed. Allowed values: US,BR,MX(defaults toUS). | 
| collectBillingAddress | Boolean | If set to trueaddress fieldsLine1,Line2(optional),City,Postal Code,Country, andStateare collected through iFrame. | 
| css | JSON string | If provided, customized CSS is applied. If ignored, default style is retained for payment wall. | 
| disableContinue | callback or string | If a string is provided, that string is interpreted as the ID of the outside Continue button (can be any element), which is disabled if no payment is selected. If a callback is provided, that callback is invoked. | 
| enableContinue | callback or string | If a string is provided, that string is interpreted as the ID of the outside Continue button (may be any element), which is enabled when a payment selection is made. If a callback is provided, that callback is invoked when the outside Continue button is clicked. | 
| onMiniBrowserClose | callback | Called when the mini browser window has been closed without completing checkout. | 
| disallowRememberedCards | Boolean | Controls whether the user is given the option of remembering cards. You may not want to deal with the integration burden of storing data for remembered cards, and if so, you should set this parameter to trueso that users do not mistakenly believe that their card will be remembered. Allowed values aretrueorfalse. Defaults tofalseso that remembering cards is enabled. | 
| hideMxDebitCards | Boolean | If trueand if the merchant is in Mexico, debit card logos are not displayed. | 
| language | string | Language in which to render the PayPal Plus payment selection page. This should be the language used in your website and checkout page so that all content is consistent for the buyer. Allowed values are: en_US,pt_BR,es_MX(defaults toen_US). | 
| merchantInstallmentSelectionOptional | Boolean | When merchantInstallmentSelectionis > 0, iftruethe payer can change the installment term; iffalseorundefined, (default) the payer cannot modify the term. | 
| miniBrowser | Boolean | If truethe application loads in a mini browser instead of an iFrame.Note: An external Continue button is not necessary if the application runs in a mini browser | 
| mode | string | Depending on the mode, the library loads the payment selection page from different locations. Allowed values are liveandsandbox. If you specifylive, it is loaded from paypal.com whereassandboxloads it from sandbox.paypal.com. The library also issues a warning to the console if the mode is set tosandbox. Inlivemode, warnings are issued only if required parameters are missing. | 
| onContinue | callback | If a callback is provided, that callback is invoked and passes the rememberedCardstoken, thepayerId, thepayment_id, and the installments term when PayPal Plus has completed finished processing payment. | 
| onError | callback | If a callback is provided, that callback is invoked when PayPal Plus throws an error. | 
| onLoad | callback | Called when the payment selection page loads successfully. | 
| rememberedCards | string | Holds the IDs needed for PayPal to retrieve the user’s remembered card data. The user can choose from those remembered cards, which expedites the payment process and improve the conversion rate. The value for this parameter should be saved in a secure way inside the user’s account and should be the exact string that is returned in the Continue response_bodyand delete card event objects. (Defaults to an empty string.) | 
Sample payment selection pages
These examples show how the payment selection page may look after your integration and configuration is complete:
 
     
Next
- Optional: Update the payment selection page
- Optional: Populate an order review page
- Required: Test your integration and execute the payment