This reference describes the JavaScript client methods to use to implement the Google Pay API in your web applications.
Constructor
Initializes the PaymentsClient object. You must call this constructor before
  calling member methods.
new PaymentsClient(paymentOptions)
Arguments
| Property | Description | 
|---|---|
| paymentOptions | An object containing key-value pairs of Google Pay API
        configuration data. See
         Example:  | 
Returns
| Type | Description | 
|---|---|
| google.payments.api.PaymentsClient | The PaymentsClientobject. | 
Throws
| Type | Description | 
|---|---|
| Error | The passed environment property value isn't supported. | 
Object methods
createButton(options)
The convenience method is used to generate a Google Pay payment button styled with the latest Google Pay branding for insertion into a webpage.
The generated HTMLElement includes dynamically inserted CSS and an SVG image
  hosted on Google's CDN.
Reference our Brand guidelines for more information about how to select the appropriate button color and button type for your site's design. You might need to alter the dimensions of the button to match similar buttons or checkout elements on your page. Use our Customize your button tool to configure a button for your use case.
Arguments
| Name | Description | 
|---|---|
| options | An object that contains key-value pairs for a button configuration.
        See  Example:  | 
Returns
| Type | Description | 
|---|---|
| HTMLElement | An HTML <button>inside a generic flow content container
        such as a<div>. | 
Throws
| Type | Description | 
|---|---|
| Error | A required property isn't set. | 
isReadyToPay(isReadyToPayRequest)
Use the isReadyToPay(isReadyToPayRequest) method to determine a user's ability
    to return a form of payment from the Google Pay API.
If the browser supports Google Pay, isReadyToPay returns true. To determine whether the
    user is logged in to a Google account, or has already saved a payment method in Google Pay, set
    IsReadyToPayRequest.existingPaymentMethodRequired
    to true and verify that
    paymentMethodPresent returns true in the resolved promise. For more
    details, see
    IsReadyToPayResponse.
  
If PaymentsClient initialized with an environment property of
    TEST, paymentMethodPresent always returns true.
Arguments
| Name | Description | 
|---|---|
| isReadyToPayRequest | An object that contains methods of payment supported by the merchant. For details on the
        different properties that are configurable, see IsReadyToPayRequest. | 
Returns
| Type | Description | 
|---|---|
| Promise | Resolved: An object that contains information about the user's ability to pay. For
          more information, see
           Rejected: An error object that contains more information about the reason for
          rejection. For more information, see
           | 
Errors
| statusCode | Description | 
|---|---|
| DEVELOPER_ERROR | 
 | 
loadPaymentData(paymentDataRequest)
This method presents a Google Pay payment sheet that allows selection of a payment method and optionally configured parameters.
This method must be called while the browser processes an activation behavior as a result of a click event. A popup window may be presented to the user to select a payment method or other required data specified in the passed request parameter.
Arguments
| Name | Description | 
|---|---|
| paymentDataRequest | An object that contains key-value pairs of full Google Pay API
        configuration.
        See PaymentDataRequestfor configurable properties. | 
Returns
| Type | Description | 
|---|---|
| Promise | Resolved: An object that contains the requested shopper data. See PaymentData for more information. Rejected: An object containing an error code and more information about the reason for rejection. See PaymentsError for more information. | 
Errors
| statusCode | Description | 
|---|---|
| CANCELED | 
 | 
| DEVELOPER_ERROR | The passed PaymentDataRequestobject was improperly formatted, missing the minimum required parameters, or
        contains an invalid parameter and/or value. | 
prefetchPaymentData(paymentDataRequest)
Use this method to prefetch a PaymentDataRequest configuration to improve
    loadPaymentData execution time on later user interaction. No value is returned.
Prefetch optimizations are available on Chrome for Android.
Arguments
| Name | Description | 
|---|---|
| paymentDataRequest | An object that contains key-value pairs of full Google Pay API
        configuration.
        See PaymentDataRequestfor configurable properties. A change in thetransactionInfoproperty doesn't affect the cached prefetch value. | 
onPaymentAuthorized(paymentData)
This method is called when a payment is authorized in the payment sheet.
Arguments
| Name | Description | 
|---|---|
| paymentData | An object that contains the requested shopper data. For details,
        see PaymentData. | 
Returns
| Type | Description | 
|---|---|
| Promise | Resolved: An object that contains information about payment transaction results.
        For details,
        see  Rejected: An error object with an error intent and message to be rendered  in the
          payment sheet. For details,
          see  | 
onPaymentDataChanged(intermediatePaymentData)
This method handles payment data changes in the payment sheet such as shipping address and shipping options.
Arguments
| Name | Description | 
|---|---|
| intermediatePaymentData | An object that contains the selected address and shipping option in
        the payment sheet. For details,
        see IntermediatePaymentData. | 
Returns
| Type | Description | 
|---|---|
| Promise | Resolved: An object that contains information about new transaction information,
        shipping options, and payment data errors. For details,
        see  Rejected: An error object with an error intent and message to be rendered  in the
          payment sheet. For details,
          see  |