Weโre all familiar with the concept of autocompletion, right? You type something into a search box, and it tries to guess what youโre looking for as you type, displaying suggestions, often below the cursor. While weโre used to autocompleting on ecommerce sites that redirect to search or product pages, an underrated usage is when used as a secondary search pattern to augment the typing experience.
In modern web applications, thereโs no reason a composition box has to be a dull, plain text area, or limit itself to rich text formatting. Social and productivity apps like Twitter, Slack, Notion, Google Docs, and Asana have popularised the โ@mentionโ pattern, allowing you to reference other users as you type. You can mention another Web designers, a channel, a file, or some other queryable object using triggers, such as the @ or # characters. This opens a panel with suggestions, letting you complete your message with the right reference.
The text box acts as a search input, and the suggestions panel acts as a typing assistant, allowing users to reference the right resource without leaving their keyboard. When implemented correctly, everything is only a few keystrokes away, including when users misspell something.
Along with powering a composition box, this pattern drives consistency in user-generated content. Hashtags are a good example: users are empowered to create semi-structured data in a free-form context, which then helps categorise content without needing to post-process it. Once users have mentioned other people in a document, referenced resources, or added several hashtags, you get a graph of connections across all the resources available on your app, making it a lot simpler to recommend related content and understand how users think.
Beyond letting users find what they want, a great @mention autocomplete feature should be as fluid as possible. The goal is to create a seamless typing experience where the pattern behaves as an assistant that learns as you type and helps you out, but knows when to get out of your way. You can keep typing, ignoring the suggestions and letting them go away, or you can leverage them to complete your message without friction.
On Twitter, which popularised the pattern with mentions and hashtags, the panel closes as soon as the word being typed is no longer considered a token, to avoid bugging users who want out. Twitter user handles donโt support spaces, so it closes the panel immediately after a space.
Slack works a bit differently, allowing spaces to let you search full names. It uses different heuristics to determine what signals that users want out.
When selecting a suggestion, Twitter closes the panel, replaces the token, and adds a space, soย the user can keep typing seamlessly. This kind of attention to detail might seem insignificant in isolation, but when they add up, they give a sense of fluidity that empowers users to embrace the pattern instead of fighting it.
When you start adding mentions in a composition box like this, they become part of your text, but should also retain full interactivity to let users edit them.
On Twitter, for example, you can โfocusโ a mention by either clicking on it or navigating the text box with the Left
and Right
arrow keys. Twitter detects it and reopens the panel with the mentions as the search query. It ensures who is notified when the tweet is sent, and allows you to edit the mention in case of a mistake.
One way to build such experiences with minimal effort is using the open-source Autocomplete library. Autocomplete is designed to integrate best with Algolia, but works with any source, static or remote. It lets you build multi-source dynamic and accessible autocomplete experiences, and works great for @mention features.
Mixing different types of suggestions
Having a symbol per result type works well when you have a few, distinct types, such as โ@โ for people, and โ#โ for hashtags. As soon as you have more types with blurrier limits, chances are good that users are unable to remember them all. Isolating them could make the experience more cumbersome.
Instead, assigning more than a single type per symbol with federated search (multi-source) helps discover all possible types without having to โlearnโ too many patterns.
On Slack, suggestions are mixed and differentiated with visual cues (such as different icons and badges). Still, the results look similar to how you experience them in the rest of the app. For example, people suggestions show the usersโ avatar, display name, and status. This helps users feel more confident about who or what they mention.
On Notion, suggestions are grouped by type. Unlike a typical search experience that favours per-result relevance, this approach favours consistency: until you refine the query, you always get dates first, then people, then links. This helps users build muscle memory as they use the tool, by setting expectations regarding where things are.
Grouping by type is achievable either by querying multiple sources at once, or using grouping mechanisms such as Autocompleteโs Reshape API, that transform results after retrieving them.
Peeking into Notionโs code, you can see how they leverage CSS Custom Properties to do this: every time you move through suggestions, they set the CSS variable --pseudoAfter--content
on the inputโs parent element with JavaScript. This CSS variable is then used with the content
property on a ::before
pseudo-element. Nifty!
When drawing results from multiple sources, it can become harder to control the number of results. Thatโs because each source might return the number of requested suggestions, or less, when it doesnโt have enough matches. This can result in a โjumpyโ UI, where the number of results fluctuate as the user types.
You can mitigate this either with a fixed height panel containing a scroll bar, or by using combine and limit mechanisms like Autocompleteโs Reshape API.
Thinking outside the search results
When you work on search and discovery every day as I do, you start seeing it everywhere. Itโs fantastic how creative you can get with the @mention pattern when you go beyond how it is typically implemented.
If youโre using Slack, you might be used to looking for emojis by typing โ:โ then refining by name. While it doesnโt look like search or mentions, it uses the same exact mechanisms: you open a suggestions panel with a special character, search for the right item, and โapplyโ it on select.
This is even more striking on Notion, where the panel doesnโt look like search results at all.
Whatโs interesting here is how versatile the pattern can be when changing simple things like item templates and styling results differently. It integrates even better in a composition box and creates a fluid experience that users recognise across all the apps they use.
Going beyond type completion
Mentions are the most common use case when using dynamic suggestions in a composition box, but you can go a lot further. While mentions help you โcompleteโ a sentence and enhance the typing experience, a composition box can also be a conversational interface between the user and the app.
On Notion, typing the special character โ/โ gives you access to inserting actions. You still get to refine suggestions by typing further, but instead of filling the input, selecting a result creates a brand-new block of a given type.
This pattern, commonly known as โshortcutsโ or โslash commandsโ was popularised in-game chats and has become a standard in general-purpose chat applications like Slack and Discord.
Shortcuts are interesting because it lets users perform common tasks in one place, without having to look for the feature. For example, itโs common to do impromptu Zoom meetings with remote coworkers and usually requires sending a Zoom link over Slack. But having to open Zoom, copy the link, then paste it into Slack is cumbersome. The โ/zoomโ shortcut removes those hurdles by centralising common tasks in a single interface.
While features like slash commands used to be dedicated to power users, theyโre now emerging in more and more apps and targeting all kinds of users.
Ultimately, augmenting the typing experience isnโt about unlocking โpower featuresโ but about uncovering content, as well as reducing friction and the cognitive load: instead of teaching users about the complexity of your system ahead of time, youโre bringing the right information at the right time, where and when users need it.