Design a great Microsoft Teams app
Microsoft Teams places content in the middle of everyday conversations. Take a look at some ideas you can use to showcase your brand within Microsoft Teams.
For more details and full guidance, complete with style guides and examples, please review our full Design guidelines.
Designing a great tab
Tabs give your app a dedicated canvas at the center of a team’s workflow, allowing teams to jump between conversations and your experience. Although it's relatively easy to adapt a web app to become a Microsoft Teams tab, you should consider which experiences and functionality in your app can work most effectively.
Select relevant app functionality
Teams add configurable tabs to channels. A channel is a specific topic or purpose that the team has. Find the concepts in your app that best fit this context; users are more likely to want to add these as tabs. For example, the Planner tab for a channel contains a single plan. The Power BI tab maps to a specific report.
Use static tabs for your single-user experience. For example, if your service is a note taking app, add a tab that holds personal notes. That way, a user can refer to his or her own notes without having to share them with an entire team.
Scope and focus the user experience
Once configured, configurable tabs should drill down to the relevant context and not let the user navigate outside of it within the tab. For example, the Power BI tab doesn't enable the user navigate to other Power BI reports within the tab. However, like many tabs based on an existing web app, it does enable the Go to website button that launches the report in the main Power BI website.
Integrate with the Microsoft Teams user experience
Your tab experience should feel integrated into Microsoft Teams. If you are adapting an existing web app, do not include your usual web app chrome or display navigational dead ends.
Consider how to enable access permissions for your tab. Microsoft Teams is based on Office 365 Groups, so consider supporting permissions for them. At a minimum, you should make it easy for each new user to request access when they visit the tab. Or consider whether you can make the content generally available without requesting additional permissions.
Designing a great bot
Bots are conversational apps that perform a narrow or specific set of tasks. They give you an opportunity to communicate with users, respond to their questions, and proactively notify them about changes. They're a great way to reach out.
In general, your bot must respond to every message, especially common questions like "help" and "hello." Your bot should also be able to handle the following types of queries and inputs:
- Recognized questions – The “best-case scenario” questions you anticipate from users
- Recognized non-questions – Queries about unsupported functionality, random pieces of information, or someone cursing at your bot
- Unrecognized questions – Unintelligible inputs (that is, gibberish)
Leverage the bot event messages to ensure that your bot introduces itself when added to a team or first accessed in a personal chat. This is an opportunity to tell the user what value you bring to their workday.
Designing a great messaging extension
Messaging extensions allow you to share cards in a conversation. A card can hold instructions to complete a complex task or a simple GIF. Microsoft Teams comes equipped with several messaging extensions already. If you look below the compose box, you’ll see a "GIF" icon. Click it, and you’ll see a menu with options to select a featured GIF or search for a specific one—that’s a messaging extension! These extensions are one of the best ways to create shareable content and serve information quickly.
Optimize your search results
A snappy messaging extension returns an easily digestible list of search results. We recommend including an image and no more than two lines of text.
Optimize your cards
Each messaging extension culminates in a card. Because it’s the last thing your user sees, be sure that your cards are useful, good-looking, and easy to share.