data:image/s3,"s3://crabby-images/2509b/2509bf13a1ad22f8b9169c70c5a152599318ba43" alt="Illustration of large contact cards"
Contacts
Whether we’re sending emails, physical mail, or following someone on social media, we primarily think in terms of names and faces, and not the respective address or user ID.
Invoices, node IDs and other transaction endpoints in bitcoin and lightning are highly unintuitive. Abstracting them via a contact list can create a much smoother user experience. There are many payment request formats, each with unique properties and varying levels of maturity and adoption, requiring unique design solutions. This page uses the more approachable term “address”, along with various UI techniques, to abstract these complexities for users.
Let’s go over common user interactions around managing contacts. This will illustrate how such a feature could work, and helps explain the underlying design problems and decisions.
Adding a contact #
The most basic interaction is that a user manually adds a contact by entering their name and an address. This is likely not the most common user flow, as most contacts will be created with incoming payment requests, as illustrated further below. But wallets should generally support manual options, as users may not be able to avoid them.
data:image/s3,"s3://crabby-images/71a95/71a95da8fbc0e01db1f3bcca408386af1b72bb1b" alt="Empty contact list screen"
Initially, a wallet’s contact list is empty. Importing them from the device can be made available.
data:image/s3,"s3://crabby-images/e0126/e0126dbd8c1c51f4ad06d8d3951d9a710f8289a9" alt="Screen asking the user to enter a name for a new contact"
All a new contact needs is a name. Other information can be added later.
data:image/s3,"s3://crabby-images/0f403/0f403aaa241c4e6c7802a1e8cd272a1e2be554b6" alt="A contact with no added information"
New contacts can already be assigned to outgoing invoices. But since no address is assigned, no outgoing payments can be made yet.
data:image/s3,"s3://crabby-images/45c4c/45c4c47804b3ff664f2c00c310b5829503edd37d" alt="Screen asking the user to enter a bitcoin address"
Users can manually enter addresses to add.
data:image/s3,"s3://crabby-images/feb2a/feb2a777deab43a4fd61ebe28655f9076046c902" alt="Address entry screen with expanded information about supported addresses"
Information about supported address formats should be readily available.
data:image/s3,"s3://crabby-images/4871d/4871d9a80e1ea6fe9d64391b2cba212f80a4e461" alt="Address entry screen with inline validation for a lightning address"
Inline validation lets users know about if addresses are accepted.
data:image/s3,"s3://crabby-images/7a073/7a073af9407436e6da114053dc0025d11169f896" alt="A contact with a lightning address assigned"
A contact with a lightning address associated.
You may choose to require user verification (like PIN entry) when adding or updating contacts. This reduces the risk that contact information is tampered with and payments are sent to wrong addresses.
Contact editing #
The contacts screen should offer various features for editing and organization.
data:image/s3,"s3://crabby-images/bdc3e/bdc3e135ce2c18737d480869cd7bfe44659e7454" alt="Contact screen with multiple transactions and addresses"
Example of a contact with multiple transactions and addresses.
data:image/s3,"s3://crabby-images/69835/698359cc96f86171b129b3358074958a12fede2e" alt="Options for editing a contacts screen"
Options for editing and organizing the contact.
data:image/s3,"s3://crabby-images/ea941/ea941704d30defd6c0c1bb4b877a1cd8d23363cc" alt="Contacts screen in edit mode"
Edit mode allows for re-ordering, deleting and renaming addresses.
data:image/s3,"s3://crabby-images/f83e3/f83e3d57d85037b3a92e334deb263c265dc2e430" alt="Contact screen with an address details modal"
Address details and options can be available on tap.
Importing an address #
This scenario can be initiated by copying a lightning address to the clipboard, scanning a QR code, or tapping a payment link (see payment entry points). An address is passed into the application and, where it’s recognized and appropriate options are shown to the user. In the example below, the user adds the address as a new contact.
data:image/s3,"s3://crabby-images/89db6/89db69a5ee9db280ca46694e88d21f31803ee5d9" alt="Modal showing that a lightning address was detected on the clipboard"
A modal is shown when an address has been imported via the clipboard or other methods.
data:image/s3,"s3://crabby-images/69171/69171ba1053b0b320abf378bd611aeecf42b3b6d" alt="Screen for selecting a contact"
The user has tapped “Add contact” and then taps “+” to add a new contact.
data:image/s3,"s3://crabby-images/f8cdc/f8cdce9d0aca2d95602d2bfbc066aacd87661a0c" alt="Contact screen with the lightning address assigned"
The new contact is created with the address associated.
Importing a payment request #
This sequence is similar to the one above. The difference is that a payment request was passed into the application, which contains different data and also includes a specific user action, and therefore requires different user flows. The one below shows how a user has scanned a payment request and assigns a contact to the payment.
Some payment request formats may include an address that can receive repeatedly. In this case, the address is added to the contact for future use. For single use payment requests, only the payment is linked.
Payment requests may also contain recipient names. These can be used to suggest the name for a new contact to the user. Names can be spoofed, so they should not be automatically assigned without user approval.
data:image/s3,"s3://crabby-images/3ed01/3ed018921288c053262753fe2193ab610b062af4" alt="Invoice modal with rich details"
This invoice includes rich data and the included address was automatically matched to an existing contact.
data:image/s3,"s3://crabby-images/2d7bd/2d7bdabea6aa601b9b930692a8584e5c5386e0d6" alt="Invoice modal with minimal payment details"
This is a minimal invoice, no matching contact could be identified.
data:image/s3,"s3://crabby-images/33324/33324df62053b0d2b161475afd1042f402d97984" alt="Screen with a list of contacts to choose from"
Tapping “Link contact” presents the user with a contact list modal.
data:image/s3,"s3://crabby-images/5b42a/5b42a98c3e132924255ba2dba8a9e2047671027b" alt="Invoice screen with a contact assigned"
A basic invoice with an assigned contact.
data:image/s3,"s3://crabby-images/8d293/8d293a1c0a58b110e0249b5694657957ec580d5e" alt="Contact with a single transaction assigned"
A contact with an assigned transaction, but no re-usable addresses.
data:image/s3,"s3://crabby-images/4bd04/4bd04f5192a9a48e7f80f801450860974017b7ec" alt="Contact with a transaction and an address assigned"
A contact with an assigned transaction and a re-usable address.
Note that automating matching of contacts to payment requests is a sensitive matter. If it cannot be based on unspoofable identifiers, then users should have to review and approve the match.
Sending from the home screen #
Initiating a payment can be as simple as entering an amount and tapping a contact that has a re-usable address associated. Otherwise, an extra step is needed to manually enter a destination address.
data:image/s3,"s3://crabby-images/9ea4c/9ea4cb1a6bd4e361eb0f10bb99a55ffe1e825641" alt="Home screen with amount input"
The user enters an amount and taps “Pay”.
data:image/s3,"s3://crabby-images/33324/33324df62053b0d2b161475afd1042f402d97984" alt="Screen with a list of contacts to choose from"
Next, the user is asked to choose a contact to send to.
data:image/s3,"s3://crabby-images/31202/31202df2a8bdaf621d4a0c95c0afbeadf3b0a6e5" alt="Invoice screen with a contact assigned"
Final review of the payment before sending it.
Adding a contact to an outgoing invoice #
Contacts can also be assigned to invoices that will be paid by others.
data:image/s3,"s3://crabby-images/4b5e2/4b5e2352feb51ac8ad45841003657754eb7318fc" alt="Home screen with amount input"
The user enters an amount and taps “Request”.
data:image/s3,"s3://crabby-images/939f1/939f1b6a345ab1c31dc5357cd6df054f2b2c4617" alt="Payment request screen"
An invoice screen with minimal information.
data:image/s3,"s3://crabby-images/11160/11160391289337895b4e81312dac24a701ca2bc5" alt="Payment request screen with a contact assigned"
The same invoice with a contact assigned.
Adding a contact to a completed payment #
When browsing the activity screen, users may come across payments they want to assign contacts to. While applications should try to automatically make connections between payments and contacts by matching addresses, this is not possible oftentimes.
data:image/s3,"s3://crabby-images/bfa2f/bfa2f272f5e0a2a148d03c97824a8eb2f85a9757" alt="Activity screen showing transactions with minimal information"
By default, payments contain little to no contextual information.
data:image/s3,"s3://crabby-images/a8656/a865644b05d7bcb64211959a10b665454d9561b2" alt="Activity screen showing transactions with assigned contacts"
Assigning contacts to payments makes them much easier to understand and work with.
data:image/s3,"s3://crabby-images/9c21e/9c21e46f14ac65aaab634d55455bb282161ab668" alt="Transaction details"
Transaction detail screens should have convenient options to assign a contact.
data:image/s3,"s3://crabby-images/33324/33324df62053b0d2b161475afd1042f402d97984" alt="Screen with a list of contacts to choose from"
The user picks a contact in a slide-up modal.
data:image/s3,"s3://crabby-images/faf1b/faf1b57bfdf00f170d193a8c51c629a10371e884" alt="Transaction details with assigned contact"
A payment with an assigned contact.
A contact card for the wallet owner #
Most contact books include a special card for the user. It is typically shown at the top of the contact list, and used for quick sharing with others. In addition to listing any addresses your wallet provides, you might choose to let users enter external addresses from other wallets for convenience.
data:image/s3,"s3://crabby-images/d7637/d7637f24c263db75eb4d0d4cc92afc4ac6ff889b" alt="Contact list screen"
The wallet owners contact card is shown at the top of the contact list.
data:image/s3,"s3://crabby-images/1dbe2/1dbe222f04a36db0d1d8228c094e1de88e527062" alt="Contact card with internal and external addresses"
The card lists addresses provided by the wallet, and allows the user to track external addresses for sharing.
Using contacts in context #
Contacts are closely intertwined with sending, requesting, and the activity screen. When designing these user flows, pay close attention to how they connect. The less convenient it is for users to assign contacts, the less likely they are to use this feature and the higher the chance that they are exposed to the complexities of the various payment request formats.
Your application should also try to provide convenient backup for contacts, for example, via automatic cloud backup.
Supporting various payment request formats #
Based on your use case, your application may choose to only support certain payment request formats. It should still recognize all formats, and provide the user with appropriate feedback. You may also choose to add warnings before permitting use of certain formats if there are privacy and security risks the user should be aware of.
Below are different examples of how you can communicate around the type of support your application provides for different formats.
data:image/s3,"s3://crabby-images/49983/49983d4a9eea1e0605bdb93b3ac1c33cf876a8b6" alt="Address entry screen with inline validation for an on-chain address"
Particular properties of address types can be pointed out right away.
data:image/s3,"s3://crabby-images/397e8/397e8170897d411a6292f15c6142602940901ab9" alt="A contact with an on-chain address assigned"
A contact with an on-chain address attached. Once a payment is made to the address, it disappears from this list as it should only be used once for best privacy.
data:image/s3,"s3://crabby-images/64be3/64be3e9c0532d6608f98eee8c937ce2eaa846bc6" alt="Add address screen with a warning users need to accept"
You may want to support certain address formats to give users flexibility, but ensure they understand the implications.
data:image/s3,"s3://crabby-images/61386/6138654419348be95e68ab53db68bdf699aacc9f" alt="Add address screen showing that an address can't be used"
Alternatively, you may not want to support certain formats. Be conscious not to lock users out of making important payments when they need to.
data:image/s3,"s3://crabby-images/69f38/69f38c1d1efccff5f2307ce88ac1e3860caf3fd1" alt="Add address screen indicating that an address format is not supported"
Make sure to recognize unsupported formats with appropriate messaging.
The next section looks at security considerations when designing a daily spending wallet.