Skip to content

Latest commit

 

History

History
167 lines (101 loc) · 11.2 KB

File metadata and controls

167 lines (101 loc) · 11.2 KB

Microsoft Teams Toolkit for Visual Studio Code

What is Teams Toolkit?

The Teams Toolkit 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.

TTK GIF

What are Teams app "Capabilities"?

Teams apps are a combination of capabilities and entry points. For example, people can chat with your app's bot (capability) in a channel (entry point).

Tab

Tabs are Teams-aware webpages embedded in Microsoft Teams. They are simple HTML tags that point to domains declared in the app manifest and can be added as part of a channel inside a team, group chat, or personal app for an individual user.

Bot

Bots allow users to interact with your web service through text, interactive cards, and task modules.

Message Extension

Message extensions allow users to interact with your web service through buttons and forms in the Microsoft Teams client.

Getting started

Open Teams Toolkit to create a new app and start coding!

GettingStarted

follow the Get Started instructions in our documentation to start with a new project.

In the Teams Toolkit for Visual Studio Code, you can easily discover all applicable commands in the sidebar and Command Palette with the keyword "Teams". It also supports Command Line Interface (CLI) to increase efficiency.

Prerequisites

Verify you have the right prerequisites for building Teams apps and install some recommended development tools. Read more details.

Node.js

As a fundamental runtime context for Teams app, Node.js v14.x, v16.x or v18.x is required. If you develop SPFx Tab app, please install v16.x.

Microsoft 365

The Teams Toolkit requires a Microsoft 365 organizational account where Teams is running and has been registered.

Azure

The Teams Toolkit may require an Azure account and subscription to deploy the Azure resources for your project.

Don’t have a Microsoft 365 account to experience building Teams app? Sign up for Microsoft Developer Program, which allows you to have a testing tenant with preconfigured permissions.

Create your project

Use the Teams Toolkit for Visual Studio Code to set up your first app project. Create your tab app project using the following steps:

  • Ensure you've installed the Microsoft Teams Toolkit for Visual Studio Code
  • Select the Teams Toolkit icon in the Visual Studio Code sidebar.
  • Select Create a New App button from the sidebar.
  • Select a capability that you want to build in your app.
  • Select an app template from the list of available templates.
  • Select JavaScript as the programming language.
  • Choose a location where your new application will be created in a new folder.
  • Type a name for your project and hit Enter.

Read more on creating new projects.

Configure your app

At its core, the Teams app embraces three components:

  • The Microsoft Teams client (web, desktop or mobile) where users interact with your app.

  • A server that responds to requests for content that will be displayed in Teams, e.g., HTML tab content or an adaptive card.

  • A Teams app package consisting of three files:

    ✔️ The manifest.json.

    ✔️ A color icon for your app to display in the public or organization app catalog.

    ✔️ An outline icon for display on the Teams activity bar.

When an app is installed, the Teams client parses the manifest file to determine needed information like the name of your app and the URL where the services are located.

  • To configure your app, navigate to the appPackage/manifest.json file and edit the manifest.
  • The toolkit will automatically update the app registration accordingly during app side-loading and publishing.

Read more on Preview and customize the manifest file.

Preview your app on your local/remote dev environment

Simply press F5 to run your first Teams app or navigate to the Debug tab in the activity bar and select the Run and Debug icon to display the Run and Debug view. By default, the toolkit will automatically help you to set up a local environment and load the app in Teams.

Run and debug

If you want to have a better estimation of how the app will behave in the cloud environment, you can deploy your resources to the cloud and preview your app with the backend running in the cloud (remote).

Read more on local debug.

Deploy your application to Azure

Deployment happens in two steps: Provisioning and Deployment. Provisioning creates all the necessary Azure resources that your application uses. It is typically done once. To provision your backend to an active Azure subscription:

  • In the Visual Studio Code Command Palette, enter "teams" and choose the command Teams: Provision.
  • You will be asked to sign into your Azure account. This is the account where Azure resources will be provisioned. Typically this is different from the Microsoft 365 account you used to sign in earlier.
  • You will be asked to select a subscription to use from the Azure account.
  • Once provisioning is completed, Visual Studio Code will pop up the notification with the message "'app name' successfully provisioned in the cloud.".

Deploy copies of your application to the provisioned Azure resources. It is typically done after every change to your application. To deploy your application to the provisioned resources in an active Azure subscription:

  • In the Visual Studio Code Command Palette, enter "teams" and choose the command Teams: Deploy.
  • Select Tab app and Backend to deploy.
  • Once deployment is finished, go to the Visual Studio Code Debug Panel (Ctrl+Shift+D / ⌘⇧-D or View -> Run) and select Launch Remote (Edge).
  • Press the start button (green arrow) to launch your app - now running remotely on Azure!

Read more on provision and deployment to Azure.

Publish your application to Teams

When your application resources and infrastructure are deployed successfully, you can publish and register your app to the Teams app catalog to share with others in your organization.

  • In the Visual Studio Code Command Palette, enter "teams" and choose the command Teams: Publish.
  • Depending on your permission, you can send your app to the admin portal directly, or manually submit the app package file to your admin to check.
  • Once your app is approved by your admin, you can see it under the Built for your org section in the Teams app store.

Read more on publishing Teams apps.

Explore Code Samples

Explore our samples to help you quickly get started with the basic Teams app concepts and code structures.

Contributing

There are many ways in which you can participate in the project, for example:

Reporting security issues

Give security researchers information on how to privately report security vulnerabilities found in your open-source project. See more details Reporting security issues.

Telemetry

The software may collect information about you and your use of the software and send it to Microsoft. Microsoft may use this information to provide services and improve our products and services. You may turn off the telemetry as described in the repository. There are also some features in the software that may enable you and Microsoft to collect data from users of your applications. If you use these features, you must comply with applicable law, including providing appropriate notices to users of your applications together with a copy of Microsoft's privacy statement. Our privacy statement is located at Microsoft Privacy Statement. You can learn more about data collection and use in the help documentation and our privacy statement. Your use of the software operates as your consent to these practices.

Telemetry Configuration

Telemetry collection is on by default. To opt out, please set the telemetry.enableTelemetry setting to false. Learn more in our FAQ.

Code of conduct

See Microsoft Open Source code of conduct.

Trademark

This project may contain trademarks or logos for projects, products, or services. Authorized use of Microsoft trademarks or logos is subject to and must follow Microsoft's Trademark & Brand Guidelines. Use of Microsoft trademarks or logos in modified versions of this project must not cause confusion or imply Microsoft sponsorship. Any use of third-party trademarks or logos are subject to those third-party's policies.

License

Copyright (c) Microsoft Corporation. All rights reserved.

Licensed under the MIT license.