============== WebPayments UI ============== User Interface for the WebPayments `Payment Request API `_ and `Payment Handler API `_. JSDoc style comments are used within the JS files of the component. This document will focus on higher-level and shared concepts. .. toctree:: :maxdepth: 5 Debugging/Development ===================== Logging ------- Set the pref ``dom.payments.loglevel`` to "Debug" to increase the verbosity of console messages. Unprivileged UI Development --------------------------- During development of the unprivileged custom elements, you can load the dialog over a file: URI or local server without even requiring a build. Simply load `toolkit/components/payments/res/paymentRequest.xhtml` in the browser. Use the debugging console to load sample data. Debugging Console ----------------- To open the debugging console in the dialog, use the keyboard shortcut **Ctrl-Alt-d (Ctrl-Option-d on macOS)**. While loading `paymentRequest.xhtml` directly in the browser, add `?debug=1` to have the debugging console open by default. Debugging the unprivileged frame with the developer tools ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ To open a debugger in the context of the remote payment frame, click the "Debug frame" button in the debugging console. Use the `tabs` variable in the Browser Content Toolbox's console to access the frame contents. There can be multiple frames loaded in the same process so you will need to find the correct tab in the array by checking the file name is `paymentRequest.xhtml` (e.g. `tabs[0].content.location`). Communication with the DOM ========================== Communication from the DOM to the UI happens via the `paymentUIService.js` (implementing ``nsIPaymentUIService``). The UI talks to the DOM code via the ``nsIPaymentRequestService`` interface. Dialog Architecture =================== Privileged wrapper XHTML document (paymentDialogWrapper.xhtml) containing a remote ``