Interaction with the selector is done by means of custom events. The selector sets up event listeners when it mounts, and convenience methods are available to interact with the selector.
For consistency and practicality, all the events are emitted to and listened from window
.
Before use, the selector needs to be registered as a custom element and inserted into the DOM. The loadSelector()
helper function facilitates both these actions, ensuring the selector is properly registered and added to the page.
To remove the selector and all event listeners, use cleanup()
.
Events are used to interact with the selector.
- open
"sats-connect_wallet-provider-selector_open"
: The selector will open and display the providers as configured using custom event'sdetails
property, which is expected to be of typeConfig
- close
"sats-connect_wallet-provider-selector_close"
: The selector will close if open. - wallet open
"sats-connect_wallet-provider-selector_walletOpen"
: The third party interacting with the selector may optionally notify the selector when the user has their wallet open or visible. The selector will display a message indicating that an operation is in progress. - wallet close
"sats-connect_wallet-provider-selector_walletClose"
. The third party interacting with the selector may optionally notify when the user has closed their wallet or it is no longer visible. The selector will stop showing that an operation is in progress if it previously received a "wallet open" event.
- select:
"sats-connect_wallet-provider-selector_select"
: Emitted when the user selects a provider. The selected provider ID is in the custom event'sdetails
property. - cancel
"sats-connect_wallet-provider-selector_cancel"
: Emitted when the user closes the selector.
Below is how third party code would interact with the selector.
sequenceDiagram
Third party code->>Window: Register "select" event handler.
Third party code->>Window: Register "cancel" event handler.
Third party code->>Window: Emit "open" event.<br/>Event payload contains config.<br/>Config contains list of wallet providers.
Window ->> Selector: Trigger "open" handler.
Selector ->> Selector: Process user interaction.
alt User makes selection
Selector->>Window: Emit "select" event.<br/>Event payload contains provider ID.
Window ->>Third party code: Trigger "select" handler.
else Users cancels
Selector->>Window: Emit "cancel" event.
Window ->>Third party code: Trigger "cancel" handler.
end
Third party code ->>Window: Emit "close" event.
Window ->> Selector: Trigger "close" handler.
Selector ->> Selector: Close
Note that the selector must be explicitly closed when the user makes a selection. This allows for the display of a "wallet open" message to the user by the app integrating the selector.
For convenience, the following methods are available to interact with the selector:
selectWalletProvider()
: Opens the selector and returns a promise with the user's selection, or rejects if the user closes the selector.walletOpen()
: Informs the selector that the user's wallet is open. The selector will display a message to the user indicating that an operation is in progress.walletClose()
: Informs the selector the user's wallet is closed.close()
: Closes the selector.
The event names used by the selector are defined in constants.ts
, which is necessary to satisfy the compiler.