Search completed in 1.38 seconds.
  
   
    PaymentRequestUpdateEvent.updateWith() - Web APIs
    
   the 
updatewith() method of the paymentrequestupdateevent interface updates the details of an existing paymentrequest.
...  syntax  paymentrequestupdateevent.
updatewith(details);  parameters    details  a paymentdetailsupdate object specifying the changes applied to the payment request:     displayitems optional  an array of paymentitem objects, each describing one line item for the payment request.
...when calling 
updatewith(), including error in the updated data causes the user agent to display the text as a general error message.
... specifications           specification    status    comment          payment request apithe definition of 'paymentrequestupdateevent.
updatewith()' in that specification.
   
 
   
    AddressErrors - Web APIs
    
 addresserrors is the type of the object returned by shippingaddresserrors in the paymentdetailsupdate passed into paymentrequestupdateevent.
updatewith() by the shippingaddresschange event handler if a change to the address resulted in a validation error occurring.
...    let shippingaddress = ev.target.shippingaddress;   let shippingaddresserrors = {};   let updatedetails = {};    if (!validcountries.includes(shippingaddress.country)) {     ev.target.shippingoptions = [];     shippingaddresserrors.country = invalidcountryerror;      updatedetails = {       error: genericaddresserror,       shippingaddresserrors,       ...defaultpaymentdetails     };   }    ev.
updatewith(updatedetails); }  see handling address changes for a description of how this code works.
...    let shippingaddress = ev.target.shippingaddress;   let shippingaddresserrors = {};   let updatedetails = {};    if (!validcountries.includes(shippingaddress.country)) {     ev.target.shippingoptions = [];     shippingaddresserrors.country = invalidcountryerror;      updatedetails = {       error: genericaddresserror,       shippingaddresserrors,       ...defaultpaymentdetails     };   }    ev.
updatewith(updatedetails); }  the shippingaddresschange event doesn't receive the paymentrequest object directly, so we fetch it from the target property of the event.
... the final step is to call the event's 
updatewith() method, passing along the updatedetails object.
   
 
   
    PaymentRequest: shippingoptionchange event - Web APIs
    
 paymentrequest.addeventlistener("shippingoptionchange", event => {   const value = calculatenewtotal(paymentrequest.shippingoption);   const total = {     currency: "eur",     label: "total due",     value,   };   event.
updatewith({ total }); }, false);   after caling a custom function, calculatenewtotal(), to compute the updated total based on the newly-selected shipping option as specified by the shippingoption.
... the revised total is submitted back to the payment request by calling the event's 
updatewith() method.
...  you can also create an event handler for shippingoptionchange using its corresponding event handler property, onshippingoptionchange:  paymentrequest.onshippingoptionchange = event => {   const value = calculatenewtotal(paymentrequest.shippingoption);   const total = {     currency: "eur",     label: "total due",     value,   };   event.
updatewith({ total }); };  specifications           specification    status    comment          payment request apithe definition of 'shippingoptionchange' in that specification.
   
 
   
    Index - Web APIs
    
actual updates are made by passing options to the 
updatewith() method.
...        2955     paymentrequestupdateevent.
updatewith()     api, change, experimental, method, payment change, payment details, payment request api, paymentrequestupdateevent, reference, secure context, web payments, payment, 
updatewith       the 
updatewith() method of the paymentrequestupdateevent interface updates the details of an existing paymentrequest.
   
 
   
    PaymentDetailsUpdate - Web APIs
    
this can be done either by calling the paymentrequestupdateevent.
updatewith() method or by using the paymentrequest.show() method's detailspromise parameter to provide a promise that returns a paymentdetailsupdate that updates the payment information before the user interface is even enabled for the first time.
...when calling 
updatewith(), including error in the updated data causes the user agent to display the text as a general error message.
   
 
   
    PaymentRequest: paymentmethodchange event - Web APIs
    
atch(err => console.log("error handling payment request: " + err));   the event handler function itself, handlepaymentchange(), looks like this:  handlepaymentchange = event => {   const detailsupdate = {};    if (event.methodname === "https://apple.com/apple-pay") {     const servicefeeinfo = calculateservicefee(event.methoddetails);     object.assign(detailsupdate, servicefeeinfo);   }    event.
updatewith(detailsupdate); }, false);   this begins by looking at the event's methodname property; if that indicates that the user is trying to use apple pay, we pass the methoddetails into a function called calculateservicefee(), which we might create to take the information about the transaction, such as the underlying credit card being used to service the apple pay request, and compute and return an paym...
... before the event handler returns, it calls the event's paymentmethodchangeevent.
updatewith.
updatewith() method to integrate the changes into the request.
   
 
   
    PaymentRequest: shippingaddresschange event - Web APIs
    
 const paymentrequest = new paymentrequest(methoddata, details, options);  paymentrequest.addeventlistener("shippingaddresschange", event => {   let detailsupdate = checkaddress(paymentrequest.shippingaddress);   event.
updatewith(detailsupate); }, false);  const checkaddress = theaddress => {   let detailsupdate = {};    // check the address, return a paymentdetailsupdate object   // with any changes or errors.
...    return detailsupdate; };   you can also establish a handler for shippingaddresschange using the onshippingaddresschange event handler property:  paymentrequest.onshippingaddresschange = event => {   let detailsupdate = checkaddress(paymentrequest.shippingaddress);   event.
updatewith(detailsupdate); };  specifications           specification    status    comment          payment request apithe definition of 'shippingaddresschange' in that specification.
   
 
   
    PaymentRequest.show() - Web APIs
    
those look like this:  async/await syntax  using await to wait for a promise to be resolved makes it possible to write the code to handle payments particularly cleanly:  async function processpayment() {   try {     const payrequest = new paymentrequest(methoddata, details, options);      payrequest.onshippingaddresschange = ev => ev.
updatewith(checkaddress(payrequest));     payrequest.onshippingoptionchange = ev => ev.
updatewith(checkshipping(payrequest));      const repsonse = await payrequest.show();     await validateresponse(response);   } catch(err) {     /* handle the error; aborterror usually means a user cancellation */   } }   in this code, the methods checkaddress() and checkshipping(), respectively, check the shipping addres...
... then/catch syntax  you can also use the older promise-based approach to work with payments, using the then() and catch() functions on the promise returned by show():  function processspayment() {   const payrequest = new paymentrequest(methoddata, details, options);    payrequest.onshippingaddresschange = ev => ev.
updatewith(checkaddress(payrequest));   payrequest.onshippingoptionchange = ev => ev.
updatewith(checkshipping(payrequest));    payrequest.show()     .then(response => validateresponse(response))     .catch(err => handleerror(err)); }   this is functionally equivalent to the processpayment() method using the await syntax.
   
 
   
    PaymentAddress.country - Web APIs
    
ss.country;  value  a domstring which contains the iso3166-1 alpha-2 code identifying the country in which the address is located, or an empty string if no country is available, which frequently can be assumed to mean "same country as the site owner."  usage notes  if the payment handler validates the address and determines that the value of country is invalid, a call to paymentrequestupdateevent.
updatewith() will be made with a details object containing a shippingaddresserrors field.
   
 
   
    PaymentDetailsBase - Web APIs
    
this can be delivered to the payment interface using either paymentdetailsupdateevent.
updatewith() or by returning it from the optional detailsupdate promise provided to the paymentrequest.show() call that begins the user interaction.
   
 
   
    PaymentMethodChangeEvent.methodDetails - Web APIs
    
  ev.
updatewith(newstuff); }; const response = await request.show();  note that the methoddetails property is being used by the calculatediscount() function to compute any payment discount, then 
updatewith() is called to update the event with the computed update.
   
 
   
    PaymentMethodChangeEvent.methodName - Web APIs
    
  ev.
updatewith(newstuff); }; const response = await request.show();  specifications           specification    status    comment          payment request apithe definition of 'paymentmethodchangeevent.methodname' in that specification.
   
 
   
    PaymentRequest.onpaymentmethodchange - Web APIs
    
  ev.
updatewith(newstuff); }; const response = await request.show();  specifications           specification    status    comment          payment request apithe definition of 'onpaymentmethodchange' in that specification.
   
 
   
    PaymentRequest.onshippingaddresschange - Web APIs
    
var payment = new paymentrequest(supportedinstruments, details, options);  request.addeventlistener('shippingaddresschange', function(evt) {   evt.
updatewith(new promise(function(resolve) {     updatedetails(details, request.shippingaddress, resolve);   })); });  payment.show().then(function(paymentresponse) {   // processing of paymentresponse exerpted for the same of clarity.
   
 
   
    PaymentRequest.onshippingoptionchange - Web APIs
    
var request = new paymentrequest(supportedinstruments, details, options);  // when user selects a shipping address request.addeventlistener('shippingaddresschange', e => {   e.
updatewith(((details, addr) => {     var shippingoption = {       id: '',       label: '',       amount: { currency: 'usd', value: '0.00' },       selected: true     };     // shipping to us is supported     if (addr.country === 'us') {       shippingoption.id = 'us';       shippingoption.label = 'standard shipping in us';       shippingoption.amount.value = '0.00';       details.total.amount.value = '55.00...
   
 
   
  
   
    PaymentRequest.shippingAddress - Web APIs
    
var payment = new paymentrequest(supportedinstruments, details, options);  payment.addeventlistener('shippingaddresschange', function(evt) {   evt.
updatewith(new promise(function(resolve) {     updatedetails(details, request.shippingaddress, resolve);   })); });  payment.show().then(function(paymentresponse) {     // processing of paymentresponse exerpted for brevity.
   
 
   
    PaymentRequest.shippingOption - Web APIs
    
  const request = new paymentrequest(methoddata, details, options); // async update to details request.onshippingaddresschange = ev => {   ev.
updatewith(checkshipping(request)); }; // sync update to the total request.onshippingoptionchange = ev => {   const shippingoption = shippingoptions.find(     option => option.id === request.id   );   const newtotal = {     currency: "usd",     label: "total due",     value: calculatenewtotal(shippingoption),   };   ev.
updatewith({ ...details, total: newtotal }); }; async function checkshipping(request) {  ...
   
 
   
   
    PaymentRequestUpdateEvent - Web APIs
    
 methods  in addition to methods inherited from the parent interface, event, paymentrequestupdateevent offers the following methods:    paymentrequestupdateevent.
updatewith() secure context  if the event handler determines that information included in the payment request needs to be changed, or that new information needs to be added, it calls 
updatewith() with the information that needs to be replaced or added.
   
 
   
    PaymentResponse.retry() - Web APIs
    
    requestorresponse.addeventlistener(event, async function listener(ev) {       const promisetovalidate = validator(requestorresponse);       ev.
updatewith(promisetovalidate);       const errors = await promisetovalidate;       if (!errors) { // yay!
   
 
   
    PaymentResponse.shippingAddress - Web APIs
    
 var payment = new paymentrequest(supportedinstruments, details, options);  request.addeventlistener('shippingaddresschange', function(evt) {   evt.
updatewith(new promise(function(resolve) {     updatedetails(details, request.shippingaddress, resolve);   })); });  payment.show().then(function(paymentresponse) {   // processing of paymentresponse exerpted for the same of brevity.
   
 
   
    PaymentResponse.shippingOption - Web APIs
    
var payment = new paymentrequest(supportedinstruments, details, options);  request.addeventlistener('shippingoptionchange', function(evt) {   evt.
updatewith(new promise(function(resolve, reject) {     updatedetails(details, request.shippingoption, resolve, reject);   })); });  payment.show().then(function(paymentresponse) {   // processing of paymentresponse exerpted for the same of brevity.