November 18th, 2021

Microsoft Teams development: All you need to know

Microsoft Teams is the ultimate messaging app for your organization—a workspace for real-time collaboration, communication, meetings, and file sharing. You can extend your Teams app in multiple ways. To be able to extend your app, it’s helpful to understand all the core capabilities and entry points that work in a collaborative space.

You can learn more and get started with the Microsoft Teams developer documentation.

But, first, Cloud Advocates Bob German and Rabia Williams are here with another video deep diving into the core concepts of Microsoft Teams application development.

Keep reading for an in-depth guide to developing apps for Teams.

Microsoft Teams app capabilities

There are multiple ways to extend Teams. Some apps only have one capability, such as a webhook, while others have more than one feature to give users various options. To display data in a central location, use a tab. To present that same information through a conversational interface, use a bot.

Read more about app capabilities.

There are more app capabilities than just tabs and bots. Messaging extensions allow users to interact with your web service through buttons and forms in the Microsoft Teams client. They can search or initiate actions in an external system from the compose message area, the command box, or directly from a message.

Read more about messaging extensions.

Apps for Teams meetings can deliver a user experience for each stage of the meeting lifecycle. Meeting lifecycle includes pre-meeting, in-meeting, and post-meeting app experience, depending on the attendee’s status.

Read more about Apps for meetings.

Microsoft Teams architecture

Once you understand the various app capabilities, it’s helpful to review the architecture behind Microsoft Teams. This diagram explains it well 😊

 

Diagram explaining Microsoft Teams architecture

Microsoft Teams manifest

A Teams application is a zip file with tree files packaged in it, essentially two icons and a manifest file. Your app can be hosted anywhere, and the Teams manifest file simply describes your application to the Microsoft Teams client.

Example of how the Microsoft Teams manifest file functions

Read more about this manifest file.

Teams Application Scopes

There are three scopes with which Teams can use your app.

  1. Teams – Your app is accessed by all members of a Teams channel.
  2. Group/Meeting – Your app can be used to show contents for a group of users or in a 1:1 chat.
  3. Personal – Your app is for personal use or an individual user, i.e. an app to display “My pending tasks for the day” or “My unread emails”

Types of Microsoft Teams application scopes

SDKs (Software Development Kits) and APIs (Application Programming Interfaces) used in Teams applications

SDKs make it easier to integrate your apps with Teams. Read more about Microsoft Teams JavaScript client SDK.

Adaptive Cards

Adaptive Cards are actionable snippets of content that you can add to a conversation through a bot or messaging extension. Using text, graphics, and buttons, these cards provide rich communication to your audience.

Read more about them Designing Adaptive Cards for your app – Teams | Microsoft Docs

Also, check out https://adaptivecards.io

Packaging and installing Teams apps

Once you have developed an application, you will need to package and install it in Teams.

Developer tools and app generators

There are a few options to create a Teams application from scratch.

Microsoft Teams Toolkit for Visual Studio Code helps developers create and deploy Teams apps with integrated Identity, access to cloud storage, data from Microsoft Graph, and other services in Azure and Microsoft 365 with a “zero-configuration” approach to the developer experience. Check out the toolkit.

There is also an open source, community-built generator based on Yeoman called Yo Teams. Yo Teams allows you to build Microsoft Teams applications based on TypeScript and node.js on your terms, in your editor of choice, without any external or online dependencies.

Leverage what you’ve already built

You don’t have to start your app from scratch if you have already built one.

  • If you have a web page or SPA, it can be a tab
  • If you have a webhook, it can be a connector
  • If you have a web service, it can be a bot or messaging extension

If you want to just build a bot, you can check out Bot builder generator which is another yeoman-based generator to build bots.

Where is the data stored?

Look at this cheat sheet to see where the Microsoft 365 data in your Teams client gets stored.

Cheat sheet to see where the Microsoft 365 data in your Teams client gets stored

If you want to retrieve Microsoft 365 data, use the Microsoft Graph API. And, if you have your own application data, it will remain wherever you have chosen to store it.

Samples used in the video

Here are the sample we showed in the video

Cheat sheet for Teams development

To build What you need to know Where to start
Tabs Task modules Configuration pages SPA development

Teams JavaScript SDK Teams Framework (“TeamsFx”)

Any framework is fine, react is easiest

https://aka.ms/TeamsDevDoc

https://aka.ms/teams-fx

Bots Messaging extensions Azure Bot Framework, Bot Builder SDKAdaptive Cards https://dev.botframework.com/

https://adaptivecards.io

Bots LUIS QnA MakerBot Framework Composer https://aka.ms/LUIS-Overview https://www.qnamaker.aihttps://aka.ms/BotFwkComposer
Access Microsoft 365 content and services Microsoft Graph API Microsoft Graph SDK Microsoft Graph Toolkit Azure Active Directory https://aka.ms/graph-docs https://aka.ms/Graph-SDK https://aka.ms/learn-graph-toolkit https://aka.ms/AzureAD
Advanced scenarios Meeting apps

Azure Communication Services

https://aka.ms/TeamsMeetingApps

https://aka.ms/ACS

 

About our community

Don’t think you are alone in this. We have a huge community at PnP | Microsoft 365 to help out with your journey in Teams app development.

To keep your finger on the pulse on all things new in Microsoft Teams, go to https://aka.ms/whatsupteams

We can’t wait to see what you build for Teams! Happy coding!

 

Author

0 comments

Discussion are closed.

Feedback