ServiceWorkerGlobalScope: canmakepayment event
Experimental: This is an experimental technology
Check the Browser compatibility table carefully before using this in production.
The canmakepayment event of the ServiceWorkerGlobalScope interface is fired on a payment app's service worker to check whether it is ready to handle a payment. Specifically, it is fired when the merchant website calls new PaymentRequest().
Syntax
Use the event name in methods like addEventListener(), or set an event handler property.
js
addEventListener("canmakepayment", (event) => {});
oncanmakepayment = (event) => {};
Event type
A CanMakePaymentEvent. Inherits from ExtendableEvent.
Examples
The canmakepayment event is fired on a payment app's service worker to check whether it is ready to handle a payment. Specifically, it is fired when the merchant website calls new PaymentRequest(). The service worker can then use the CanMakePaymentEvent.respondWith() method to respond appropriately:
js
self.addEventListener("canmakepayment", (e) => {
e.respondWith(
new Promise((resolve, reject) => {
someAppSpecificLogic()
.then((result) => {
resolve(result);
})
.catch((error) => {
reject(error);
});
})
);
});
respondWith() returns a Promise that resolves with a boolean value to signal that the service worker is ready to handle a payment request (true), or not (false).
Specifications
| Specification |
|---|
| Payment Handler API # the-canmakepaymentevent |
Browser compatibility
BCD tables only load in the browser