PaymentManager

Experimental: This is an experimental technology
Check the Browser compatibility table carefully before using this in production.

Secure context: This feature is available only in secure contexts (HTTPS), in some or all supporting browsers.

The PaymentManager interface of the Payment Handler API is used to manage various aspects of payment app functionality.

It is accessed via the ServiceWorkerRegistration.paymentManager property.

Instance properties

userHint Experimental

Provides a hint for the browser to display along with the payment app's name and icon in the Payment Handler UI.

Instance methods

enableDelegations() Experimental

Delegates responsibility for providing various parts of the required payment information to the payment app rather than collecting it from the browser (for example, via autofill).

Examples

js
navigator.serviceWorker.register("serviceworker.js").then((registration) => {
  registration.paymentManager.userHint = "Card number should be 16 digits";

  registration.paymentManager
    .enableDelegations(["shippingAddress", "payerName"])
    .then(() => {
      // ...
    });

  // ...
});

Specifications

Browser compatibility

Desktop Mobile
Chrome Edge Firefox Opera Safari Chrome Android Firefox for Android Opera Android Safari on IOS Samsung Internet WebView Android
PaymentManager 70 79 No 57 No 70 No 49 No 10.0 No
enableDelegations 80 80 No 67 No 80 No 57 No 13.0 No
instruments 70–111 79–111 No 57–97 No 70–111 No 49–75 No 10.0–22.0 No
userHint 70 79 No 57 No 70 No 49 No 10.0 No

See also

© 2005–2023 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/PaymentManager