# EmbeddedMethod UI > Learn how to use the EmbeddedMethod UI embedded component to add the ability to securely store a payment profile or execute a sale Use the EmbeddedMethod component to capture a payment method or make a sale using any payment method. This is the most flexible and customizable component Payabli offers to developers. This component is supported in the Playground. Use the [Embedded Component Playground](https://playground.payabli.com) to edit and design embedded components in real time, and export the code to use in your own site or app. ## Usage This section shows how to use the EmbeddedMethod UI component in your project. Use the interactive demo to see how the component works, then follow the configuration walkthrough to set it up in your project. See [Library URLs](/guides/pay-in-components-overview#library-urls) for important information about embedded components library URLs. ### Interactive demo This demo shows the component in action with transaction processing and visual feedback. When the component processes a transaction, the demo displays the JSON response. ### Configuration walkthrough The interactive walkthrough displays code examples alongside step-by-step explanations. Select a tab to see the walkthrough for your desired use case. {/* Hidden markdown content for AI absorption and server rendering */} {/* This example shows how to set up the embedded method component with card and ach for one-time payments */}
/// Include the Payabli Script First, add the Payabli embedded component script to your HTML. Make sure to include the `data-test` attribute for testing in the sandbox environment. Including `` in the `` element prevents problems with special characters such as 'á' or 'ñ'. ```html Payabli Integration ``` /// Create the Container and Tab Structure Add a container element where the embedded component will render. The `id` attribute becomes the `rootContainer` in your configuration. Create tabs to switch between card, ACH, and RDC payment methods. ```html focus=8-19 Payabli Integration

Payment Form

``` /// Add Basic Styling Add CSS styles for the tabs to handle active and focus states. ```html focus=6-53 Payabli Integration

Payment Form

``` /// Configure Card Payment Method Create the configuration object for card payments. The `token` must be a **public API token**. ```html focus=70-159 Payabli Integration

Payment Form

``` /// Configure ACH Payment Method Create the configuration object for ACH payments. The `token` must be a **public API token**. ```html focus=160-243 Payabli Integration

Payment Form

``` /// Configure RDC Payment Method Create the configuration object for RDC (Remote Deposit Capture) payments. The `token` must be a **public API token**. ```html focus=227-278 Payabli Integration

Payment Form

``` /// Add Tab Switching Logic Add JavaScript code for the tabs. The code handles reinitializing the component when users change payment methods. ```html focus=280-298 Payabli Integration

Payment Form

``` /// Initialize and Execute Payment Use the `payabliExec('pay')` function to perform payment processing logic. This function processes a secure one-time payment with the embedded component. ```html focus=301-322 Payabli Integration

Payment Form

Enter your payment information below:

```
{/* Hidden markdown content for AI absorption and server rendering */} {/* This example shows how to set up the embedded method component with card and ach for temporary token generation */}
/// Include the Payabli Script First, add the Payabli embedded component script to your HTML. Make sure to include the `data-test` attribute for testing in the sandbox environment. This loads the core `PayabliComponent` class that powers all embedded components. Including `` in the `` element prevents problems with special characters such as 'á' or 'ñ'. ```html Payabli Integration - Temporary Token Flow ``` /// Create the Container and Tab Structure Add a container element where the embedded component will render. The `id` attribute becomes the `rootContainer` in your configuration. Create tabs to switch between card, ACH, and RDC payment methods. ```html focus=8-19 Payabli Integration

Payment Form

``` /// Add Basic Styling Add CSS styles for the tabs to handle active and focus states. ```html focus=6-53 Payabli Integration

Payment Form

``` /// Configure Card Payment Method Create the configuration object for card payments with `temporaryToken: true`. This setting enables the temporary token flow. See [Temp token flow](/guides/platform-developer-tokenization-temp-flow) for more information about the temporary token flow. The `token` must be a **public API token**. ```html focus=69-158 Payabli Integration

Payment Form

``` /// Configure ACH Payment Method Create the configuration object for ACH payments with `temporaryToken: true`. The `token` must be a **public API token**. ```html focus=160-243 Payabli Integration

Payment Form

``` /// Configure RDC Payment Method Create the configuration object for RDC (Remote Deposit Capture) payments with `temporaryToken: true`. The `token` must be a **public API token**. ```html focus=235-286 Payabli Integration

Payment Form

``` /// Add Tab Switching Logic Add JavaScript code for the tabs. The code handles reinitializing the component when users change payment methods. ```html focus=288-306 Payabli Integration

Payment Form

``` /// Initialize and Execute Token Generation Use the `payabliExec('method')` function to trigger temporary token generation. This function generates a secure temporary token for the payment method entered into the embedded component. For more information on using temporary tokens, see [Extend embedded components with the temporary token flow](/guides/platform-developer-tokenization-temp-flow). ```html focus=301-313 Payabli Integration

Payment Form

Enter your payment information to generate a temporary token:

```
### Configuration reference These are the configuration parameters available for the EmbeddedMethod component. If you need to pass more than data than what's supported, consider using the temporary token flow. See [Temporary Token Flow](/guides/platform-developer-tokenization-temp-flow) for more information. This value determines the type of embedded component to render.\ Accepted values are: `methodEmbedded`, `methodLightbox`, `vterminal`, or `expressCheckout`.\ For the EmbeddedMethod UI, this value is `methodEmbedded`. See the [Embedded Components Overview](/guides/pay-in-components-overview) for more information on other component types. Container ID used for the component. Sets the default payment method that's shown. Accepted values are: `card` or `ach`. When true the component is hidden when it's instanced. API token for authentication. This should be a **public** API token, as described [here](/developers/api-reference/api-overview#authentication#organization-token-most-common). When `true`, the component uses the `customerData` object to create a new customer record. When `temporaryToken` is `true` and `forceCustomerCreation` is `false`, the component doesn't create a new customer record. See [Temporary Token Flow](/guides/platform-developer-tokenization-temp-flow#disable-customer-creation) for more information. Complete URL of a custom CSS stylesheet to use with the component. When `true`, the entered values on the form are cleared when submitted. When `true`, the token created for the payment is temporary. Set this parameter to false to create a storedMethodId and save the payment profile. When `false`, the validation error appears below the field instead of above it in a popover. When the API token belongs to an organization, the entrypoint name identifies the target paypoint (merchant). `cardService` object used to configure accepted card types. Enable/disable card option. Enable/disable acceptance of American Express cards. Enable/disable acceptance of Discover cards. Enable/disable acceptance of Visa cards. Enable/disable acceptance of MasterCard cards. Enable/disable acceptance of Diner's Club cards. Enable/disable acceptance of JCB cards. Card input fields descriptors. This object applies only to the EmbeddedMethod UI component. Optional, but *strongly recommended*. Descriptor object for input field. Descriptor object for input field. Descriptor object for input field. Descriptor object for input field. Optional, but *strongly recommended*. Descriptor object for input field. `achService` object used to configure accepted ACH types. Enable/disable ACH option. Enable/disable acceptance of Checking account. Enable/disable acceptance of Savings account. When set to true, the embedded component will validate ACH account and routing numbers in real time. This is an add-on feature. Contact the Payabli team for more information. ACH input field descriptors. This only applies to the EmbeddedMethod UI component. Required. Descriptor object for input field. Required. Descriptor object for input field. Required. Descriptor object for input field. Use the `confirm` input descriptor to add matching validation to this field. See [Style Individual Fields](/guides/pay-in-components-overview#style-individual-fields) for more. Required. Descriptor object for input field. Use the `confirm` input descriptor to add matching validation to this field. See [Style Individual Fields](/guides/pay-in-components-overview#style-individual-fields) for more. `rdcService` object used to configure accepted RDC types. Enable/disable RDC option. Amount to collect via RDC. RDC input field descriptors. Descriptor object for input field. `paymentMethod` object with data related to the payment method. **Required when saving a payment method or executing a payment**. Can be passed to the component via payabliExec method. Customer Object with data related to customer. Can be passed to the component as a parameter with the `payabliExec` method. **Required when saving a payment method**. Which fields are required depends on whether the paypoint has custom identifiers. If you aren't using custom identifiers, then you must include at least one of these values: `firstname` and `lastname`, `email`, or `customerId`. `paymentDetails` object with data related to the payment. **Required to save a payment method**. Can be passed to the component via payabliExec method. When `true`, if tokenization fails, Payabli will attempt an authorization transaction to request a permanent token for the card. If the authorization is successful, the card will be tokenized and the authorization will be voided automatically. The amount for the `fallbackAuth` transaction. Defaults to one dollar. The callback function called when the component executes successfully. The callback function called when the component receives an error. See [functionCallBackError response](#functioncallbackerror-response) in the next section for a complete reference. The callback function called when the component's status changes. Used to poll the form's completeness before showing the submit button. ## Response The embedded component returns a response object to the callback functions defined in the configuration. The response object contains the result of the transaction (success, declined, or error) and details about the transaction. ### Response examples Click the tab to see an example response returned by the embedded component for each result. ```js Payment success { responseText: "Success", responseData: { authCode: "123456", referenceId: "40-692c62895d1541d28c0bf77b275a26e4", resultCode: 1, resultText: "Approved", avsResponseText: "", cvvResponseText: "", customerId: 706, methodReferenceId: null } } ``` ```js Payment decline { responseText: "Declined", responseData: { authCode: null, referenceId: "40-2c437c3dcdc242bea96f52bdf42d2eeb", resultCode: 2, resultText: "200: Decline. Generally insufficient funds or incorrect card data supplied, for example, expiry date or security code.. DECLINE", avsResponseText: "", cvvResponseText: "", customerId: 706, methodReferenceId: null } } ``` ```js Stored method success { responseText: "Success", responseData: { referenceId: "187-c5892026d9f345ffa63bf909d574fe92", resultCode: 1, resultText: "Added", customerId: 1636, methodReferenceId: "187-c5892026d9f345ffa63bf909d574fe92" } } ``` ```js Stored method decline { responseText: "Declined", responseData: { referenceId: "187-d2a29970fa604edba5a6dbec67ace3ae", resultCode: 2, resultText: "200: Transaction was declined by processor.. DECLINE", customerId: 1636, methodReferenceId: "187-d2a29970fa604edba5a6dbec67ace3ae" } } ``` ### Response reference The response object passed to a callback function has the following structure: "Success" or "Declined" Container for response details. Authorization code for payments. This field has a value of `null` for saved payment methods. Identifier for the transaction (for payments) or the stored payment method (for save payment method). Result of operation. 1 is success, 2 is declined, and 3 is error. Message related the result. If the operation was successful, it returns "Added"/"Approved". If there was an error, it returns error details. Result of address validation for card transactions. This field is an empty string when processing ACH transactions. This field doesn't exist when saving payment methods. Result of CVV validation for card transactions. This field is an empty string when processing ACH transactions. This field doesn't exist when saving payment methods. ID for the customer owner of payment or saved payment method. Identifier for stored payment method for saved payment methods. This field has a value of `null` for payment transactions. The `methodReferenceId` is used as the `storedMethodId` in other operations. See [Handling responses and errors](/guides/pay-in-components-overview#handling-responses-and-errors) for more. ### `functionCallBackError` response The `functionCallBackError` function is called when the component can't validate the payment information before submitting it to Payabli's API. The response object passed to `functionCallBackError` contains an array with codes, keys, and descriptions of failed validations. You can check the values in the array to offer your customized error message.
Code Key Description
802 paymentMethodsCardNumberError Error in Card number field
803 paymentMethodsCardExpirationDateError Error in Card Expiration field
804 paymentMethodsCardCvvError Error in CardCVV field
805 paymentMethodsCardZipcodeError Error in Card Zip code field
901 paymentMethodsAchAccountHolderNameError Error in ACH Holder field
902 paymentMethodsAchAccountTypeError Error in ACH Account type field
903 paymentMethodsAchRoutingError Error in ACH Routing field
904 paymentMethodsAchAccountError Error in ACH Account number field
## Usage Flows These flowcharts illustrate the path to making a payment or storing a payment method using an embedded component. ### Make a payment To make a payment with an embedded component, your component configuration should contain `payabliExec(pay, parameters)`. In the `parameters` argument, include `customerData` and `paymentDetails` objects. When the payment is executed, the request returns response data. *This flowchart explains the basic steps for the task. Hover over a step for more information.*
Run `payabliExec(pay, parameters)` The action is set to `pay` here. Send the `paymentDetail` and `customerData` object in `parameters`.
Payment executed The transaction is executed and includes the data sent as parameters
Response
### Save a payment method To save a payment method with an embedded component, your component configuration should contain `payabliExec(method, parameters)`. In the `parameters` argument, include `customerData` and `paymentDetails` objects. When the payment method is saved, the request returns response data. *This flowchart explains the basic steps for the task. Hover over a step for more information.*
Run `payabliExec(method, parameters)` The action is set to `method` here. Send the `paymentDetail` and `customerData` object in `parameters`.
Payment method saved The payment method is saved and includes the data sent as parameters
Response
### Save a payment method and make a payment You can save a payment method and make a payment with the EmbeddedMethod UI component by writing a callback function to execute the payment after successfully saving the payment method. To save a payment method and then execute a transaction with the saved payment method, your component configuration should contain `payabliExec(method, parameters)`. In the `parameters` argument, include the `customerData` and `paymentDetails` objects. When the payment method is saved, use a callback function to execute the transaction. Remember to never make payment transactions via client-side API requests. Your callback function should make the payment transaction using a server-side function. *This flowchart explains the basic steps for the task. Hover over a step for more information.*
Run `payabliExec(method, parameters)` Here, the action is set to `method`. Send the `paymentDetail` and `customerData` object in `parameters`.
Payment method saved The payment method is saved and includes the data sent as parameters. An ID for the payment method is returned, which is then used to make transactions.
Callback function Use a callback function to send a transaction that uses the new payment method.
Response
## Related resources See these related resources to help you get the most out of Payabli. * **[Embedded components framework integrations](/guides/pay-in-developer-components-frameworks)** - Learn how to use Payabli's embedded components with front-end frameworks like React and Vue * **[Temporary token example app](/guides/platform-tokenization-temp-token-app)** - Go through a guided checkout experience using the temporary token flow * **[Extend embedded components with the temporary token flow](/guides/platform-developer-tokenization-temp-flow)** - Use the temporary token flow with embedded components to have complete control over user transaction experience without expanding PCI scope * **[Embedded components overview](/guides/pay-in-components-overview)** - Learn how to use Payabli's embedded components to create customized checkout experiences without handling sensitive payment information yourself