diff --git a/README.md b/README.md index aaa6d0375..56496982e 100644 --- a/README.md +++ b/README.md @@ -22,12 +22,13 @@ The easy way to browse through all the samples is to visit the [Microsoft 365 Sa 1. [Scenario specific samples](#Scenario-specific-samples) ## [Microsoft 365 Copilot samples](https://github.com/OfficeDev/Copilot-for-M365-Samples) -| Name | Description | .NET | TypeScript | JavaScript | -| -------- | :------- | ------- | ------- | ------- | -| Northwind Inventory | Plugin that allows users to query the Northwind Database | [View](https://github.com/OfficeDev/Copilot-for-M365-Samples/tree/main/samples/msgext-northwind-inventory-csharp)| [View](https://github.com/OfficeDev/Copilot-for-M365-Plugins-Samples/tree/main/samples/msgext-northwind-inventory-ts) | | -| Document Search | Plugin that enables Hybrid Search (Vector + Semantic) | [View](https://github.com/OfficeDev/Copilot-for-M365-Plugins-Samples/tree/main/samples/msgext-doc-search-csharp) | [View](https://github.com/OfficeDev/Copilot-for-M365-Plugins-Samples/tree/main/samples/msgext-doc-search-js) | | -| Product support | Plugin that allows users to query the Products held in SharePoint Online team site via Microsoft Graph | [View](https://github.com/OfficeDev/Copilot-for-M365-Plugins-Samples/tree/main/samples/msgext-product-support-sso-csharp) | | -| Multi Parameters |Plugin that demonstrates how to implement complex utterances and support deep retrieval | [View](https://github.com/OfficeDev/Copilot-for-M365-Plugins-Samples/tree/main/samples/msgext-multiparam-csharp) |[View](https://github.com/OfficeDev/Copilot-for-M365-Plugins-Samples/tree/main/samples/msgext-multiparam-ts) | [View](https://github.com/OfficeDev/Copilot-for-M365-Plugins-Samples/tree/main/samples/msgext-multiparam-js)| +| Name | Description | Level | .NET | TypeScript | JavaScript | +| ------------------ | :----------------------------------------------------------------------- | :----------: | --------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------- | +| Product support | Plugin that allows users to query the Products held in SharePoint Online team site via Microsoft Graph | Basic | [View](https://github.com/OfficeDev/Copilot-for-M365-Plugins-Samples/tree/main/samples/msgext-product-support-sso-csharp) | | | +| Northwind Inventory | Plugin that allows users to query the Northwind Database | Intermediate | [View](https://github.com/OfficeDev/Copilot-for-M365-Samples/tree/main/samples/msgext-northwind-inventory-csharp) | [View](https://github.com/OfficeDev/Copilot-for-M365-Plugins-Samples/tree/main/samples/msgext-northwind-inventory-ts) | | +| Document Search | Plugin that enables Hybrid Search (Vector + Semantic) | Advanced | [View](https://github.com/OfficeDev/Copilot-for-M365-Plugins-Samples/tree/main/samples/msgext-doc-search-csharp) | [View](https://github.com/OfficeDev/Copilot-for-M365-Plugins-Samples/tree/main/samples/msgext-doc-search-js) | | +| Multi Parameters | Plugin that demonstrates how to implement complex utterances and support deep retrieval | Advanced | [View](https://github.com/OfficeDev/Copilot-for-M365-Plugins-Samples/tree/main/samples/msgext-multiparam-csharp) | [View](https://github.com/OfficeDev/Copilot-for-M365-Plugins-Samples/tree/main/samples/msgext-multiparam-ts) | [View](https://github.com/OfficeDev/Copilot-for-M365-Plugins-Samples/tree/main/samples/msgext-multiparam-js) | + ## [Samples built using new generation of Teams development tool - Teams Toolkit](https://github.com/OfficeDev/TeamsFx-Samples) @@ -36,125 +37,124 @@ The [Teams Toolkit](https://marketplace.visualstudio.com/items?itemName=TeamsDev ## [Getting Started - Samples and Tutorials](https://docs.microsoft.com/microsoftteams/platform/tutorials/get-started-dotnet-app-studio) -| | Sample Name | Description | C# | TypeScript | App Manifest -|:--:|:-------------------|:---------------------------------------------------------------------------------------------------------------------------|:--------|:-------------|:-------------| -|1|Hello World|A Microsoft Teams Hello World sample app built with .NET/NodeJS that demonstrates essential features like tabs, bots, and messaging extensions for seamless interaction within the Teams environment.|[View][app-hello-world#cs]|[View][app-hello-world#ts] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/app-hello-world/csharp/demo-manifest/app-hello-world.zip) +| | Sample Name | Description | Level | C# | TypeScript | App Manifest | +|:--:|:-------------------|:---------------------------------------------------------------------------------------------------------------------------|:-----------:|:--------|:-------------|:-------------| +| 1 | Hello World | A Microsoft Teams Hello World sample app built with .NET/NodeJS that demonstrates essential features like tabs, bots, and messaging extensions for seamless interaction within the Teams environment. | Basic | [View][app-hello-world#cs] | [View][app-hello-world#ts] ![toolkit-icon](assets/toolkit-icon.png) | [View](/samples/app-hello-world/csharp/demo-manifest/app-hello-world.zip) | ## [AI samples](https://learn.microsoft.com/en-us/azure/ai-services/document-intelligence/?view=doc-intel-4.0.0) -| | Sample Name | Description | C# | JavaScript | App Manifest -|:--:|:-------------------|:---------------------------------------------------------------------------------------------------------------------------|:--------|:-------------|:-------------| -|1|api-doc-search|This is a sample API application that demonstrates how to perform RAG-based semantic search using NoSQL CosmosDB.||[View][api-doc-search#nodejs]|- -|2|Compliance Checker|Use Azure OpenAI to compare proposal documents against a guideline document and return whether the proposal complies and why/why not.||[View][msgext-ai-doc-compliance-checker#nodejs] ![toolkit-icon](assets/toolkit-icon.png)|[View](/samples/msgext-ai-doc-compliance-checker/demo-manifest/AIComplianceChecker.zip) -|3|bot-virtual-assistant|This is a sample application that demonstrates a root bot that routes inputs to skill bots for tailored responses.||[View][bot-virtual-assistant#nodejs]|- -|4|msgext-expert-finder-js|This sample implements a Teams message extension for Copilot, enabling users to query a database of candidates based on skills, location, and availability.||[View][msgext-expert-finder#nodejs]|- -|5|bot-ai-meeting-helper|This sample demonstrates how Azure Open AI extracts action items from meeting transcriptions for all participants who subscribed to the meeting, and subsequently sends these action items to each individual user in a 1:1 chat after the meeting concludes.||[View][bot-ai-meeting-helper#nodejs] ![toolkit-icon](assets/toolkit-icon.png)|[View](/samples/bot-ai-meeting-helper/demo-manifest/bot-ai-meeting-helper.zip) +| | Sample Name | Description | Level | C# | JavaScript | App Manifest | +|:--:|:----------------------|:---------------------------------------------------------------------------------------------------------------------------|:------------:|:-----:|:-----------|:-------------| +| 1 | msgext-expert-finder-js | This sample implements a Teams message extension for Copilot, enabling users to query a database of candidates based on skills, location, and availability. | Basic | | [View][msgext-expert-finder#nodejs] | - | +| 2 | api-doc-search | This is a sample API application that demonstrates how to perform RAG-based semantic search using NoSQL CosmosDB. | Intermediate | | [View][api-doc-search#nodejs] | - | +| 3 | Compliance Checker | Use Azure OpenAI to compare proposal documents against a guideline document and return whether the proposal complies and why/why not. | Advanced | | [View][msgext-ai-doc-compliance-checker#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | [View](/samples/msgext-ai-doc-compliance-checker/demo-manifest/AIComplianceChecker.zip) | +| 4 | bot-virtual-assistant | This is a sample application that demonstrates a root bot that routes inputs to skill bots for tailored responses. | Advanced | | [View][bot-virtual-assistant#nodejs] | - | +| 5 | bot-ai-meeting-helper | This sample demonstrates how Azure Open AI extracts action items from meeting transcriptions for all participants who subscribed to the meeting, and subsequently sends these action items to each individual user in a 1:1 chat after the meeting concludes. | Advanced | | [View][bot-ai-meeting-helper#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | [View](/samples/bot-ai-meeting-helper/demo-manifest/bot-ai-meeting-helper.zip) | ## [Tabs samples](https://docs.microsoft.com/microsoftteams/platform/tabs/what-are-tabs) -| | Sample Name | Description | C# | TypeScript | JavaScript | App Manifest| -|:--:|:-------------------|:----------------------------------------------------------------------------------------------|:--------|:-------------|:---------|:--------| -|1|Personal tabs | Sample app showing custom personal Tab with ASP. NET Core |[MVC][personal-tab#cs#mvc], [Razor][personal-tab#cs#razor] | [Yeoman Generator](https://docs.microsoft.com/en-us/microsoftteams/platform/get-started/get-started-yeoman) | |[View](/samples/tab-personal/mvc-csharp/demo-manifest/tab-personal.zip) | -|2|Personal tab quick-start| Sample personal tab quick-start app. | |[View][personal-tab-quickstart#ts] ![toolkit-icon](assets/toolkit-icon.png) |[View][personal-tab-quickstart#js] ![toolkit-icon](assets/toolkit-icon.png) -|3|Personal tab with SSO quick-start| Sample personal tab with SSO hello world app. |[View][personal-tab-sso-quickstart#csharp]|[View][personal-tab-sso-quickstart#ts] ![toolkit-icon](assets/toolkit-icon.png) |[View][personal-tab-sso-quickstart#js] ![toolkit-icon](assets/toolkit-icon.png) -|4|Channel and group tabs | Sample app showing custom group and channel Tab with ASP. NET Core |[MVC][group-channel-tab#cs#mvc], [Razor][group-channel-tab#cs#razor] | [Yeoman Generator](https://docs.microsoft.com/en-us/microsoftteams/platform/get-started/get-started-yeoman) | |[View](/samples/tab-channel-group/mvc-csharp/demo-manifest/tab-channel-group.zip) | -|5|Channel and group tab quick-start| Sample channel and group tab hello world app. | |[View][group-tab-quickstart#ts] ![toolkit-icon](assets/toolkit-icon.png) |[View][group-tab-quickstart#js] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/tab-channel-group-quickstart/js/demo-manifest/tab-channel-group-quickstart.zip) | -|6|Channel and group tab with SSO quick-start| Sample channel and group tab with SSO hello world app. |[View][group-tab-sso-quickstart#csharp]|[View][group-tab-sso-quickstart#ts] ![toolkit-icon](assets/toolkit-icon.png) |[View][group-tab-sso-quickstart#js] ![toolkit-icon](assets/toolkit-icon.png) -|7|SPFx Tab | Sample app showing Microsoft Teams tabs using SharePoint Framework | | [View][group-channel-tab#ts#spfx] | -|8|Tab SSO | Microsoft Teams sample app demonstrating Azure AD SSO in a Teams tab using C#. |[View][tab-sso#cs] | [View][tab-sso#ts] ![toolkit-icon](assets/toolkit-icon.png) -|9|Config Tab Authentication | Microsoft Teams sample app for config tabs Azure AD authentication | [View][tab-channel-group=config-csharp] | | |[View](/samples/tab-channel-group-config-page-auth/csharp/demo-manifest/tab-channel-group-config-page-auth.zip) -|10|Deep Link consuming Subentity ID | Microsoft Teams sample app for demonstrating deeplink from Bot chat to Tab consuming Subentity ID | [View][tab-deeplink#csharp] | | [View][tab-deeplink#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | -|11|Integrate graph toolkit component in teams tab | Microsoft Teams tab sample app for demonstrating graph toolkit component |[View][tab-graph-toolkit#csharp]|[View][tab-graph-toolkit#js] ![toolkit-icon](assets/toolkit-icon.png)| -|12|Device permissions | Microsoft Teams tab sample app for demonstrating device permissions | | [View][tab-device-permissions#js] ![toolkit-icon](assets/toolkit-icon.png) ||[View](/samples/tab-device-permissions/nodejs/demo-manifest/tab-device-permissions.zip)| -|13|Tab in stage view | This sample app demonstrates the use of Teams tab in stage view using C#, showcasing collaborative features and interactive elements. |[View][tab-stage-view#csharp] | | [View][tab-stage-view#js] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/tab-stage-view/csharp/demo-manifest/tab-stage-view.zip)| -|14|Create Conversational tab | Microsoft Teams tab sample app for demonstrating create conversation tab | [View][tab-conversation#csharp] | |[View][tab-conversation#nodejs] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/tab-conversations/csharp/demo-manifest/tab-conversations.zip) -|15| Product inspection | Demonstrating a feature where user can scan a product and mark it as approved/rejected. |[View][tab-product-inspection#csharp]| |[View][productinspection#nodejs] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/tab-product-inspection/csharp/demo-manifest/Tab-Product-Inspection.zip) -|16| Staggered Permission | This sample demos app to request staggered Graph API permissions in Teams tabs. |[View][tab-staggered-permission#csharp]||[View][tab-staggered-permission#nodejs] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/tab-staggered-permission/csharp/demo-manifest/tab-staggered-permission.zip) -|17| Tab people picker | This is an tab app which shows the feature of client sdk people picker. |[View][tab-people-picker#csharp]||[View][tab-people-picker#nodejs] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/tab-people-picker/csharp/demo-manifest/Tab-People-Picker.zip) -|18| Tab channel context | This sample shows the contents of tab context object in a private and shared channel. ||[View][tab-channel-context#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | -|19| Tab app monetization | This sample shows how to open purchase dialog and trigger purchase flow using teams-js sdk. ||[View][tab-app-monetization#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | -|20| Personal Tab with Nav-Bar menu | Add multiple actions to the upper right in Nav-Bar and build an overflow menu for extra actions in an app. ||[View][tab-navbar-menu#ts] ![toolkit-icon](assets/toolkit-icon.png) | -|21| App Caching in Meetings | This sample shows how to improve the subsequent loading time of an App. |||[View][app-cache-meetings#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | -|22| Tab Multi Hub | Interact with the user's calendar, mail, profile, geolocation from personal tabs app. ||[View][tab-multi-hub#ts] ![toolkit-icon](assets/toolkit-icon.png) | -|23| tab-ui-templates | This sample app provides tested, high-quality UI templates to help developers understand how to create effective applications for Microsoft Teams, covering common use cases like dashboards and forms. ||[View][tab-ui-templates#ts] ![toolkit-icon](assets/toolkit-icon.png) | -|24| Tab External Auth | This sample illustrates how to implement Google auth using external auth providers. |[View][tab-external-auth#csharp]|| -|25| Tab Meeting Tanscript Recording |This sample shows meeting transcripts and recordings. |[View][tab-meeting-transcript-recording#csharp]|[View][tab-meeting-transcript-recording#nodejs] ![toolkit-icon](assets/toolkit-icon.png)| -|26| Tab DeepLink Pass Values |Microsoft Teams sample which displays deeplinks based on the values passed dynamically to the context. ||[View][tab-deeplink-pass-values#ts]| -|27| Tab Meeting Recording and transcript with auto recording |This sample shows meeting recording and transcript with auto recording. |[View][tab-meeting-auto-recording#csharp]|| -|28| Offline Support Tickets |This sample app demonstrates a classic CRUD application that functions offline within Microsoft Teams. When the Android device reconnects to the internet, users can sync their data with blob storage. ||[View][tab-support-offline#nodejs] ![toolkit-icon](assets/toolkit-icon.png)|[View](/samples/tab-support-offline/nodejs/demo-manifest/tab-support-offline.zip) -|29| Nested App Authentication |This sample shows nested app authentication (NAA) is a new protocol that simplifies single sign-on (SSO) for single page applications. |[View][tab-nested-auth#cs]|[View][tab-nested-auth#nodejs] ![toolkit-icon](assets/toolkit-icon.png)| +| # | Sample Name | Description | Level | C# | TypeScript | JavaScript | App Manifest | +|----|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-----------------------------------------|----------------------------------------------|---------------------------------------------|--------------------------------------------------------------------| +| 1 | Personal tabs | Sample app showing custom personal Tab with ASP.NET Core. | Basic | [MVC][personal-tab#cs#mvc], [Razor][personal-tab#cs#razor] | [Yeoman Generator](https://docs.microsoft.com/en-us/microsoftteams/platform/get-started/get-started-yeoman) | | [View](/samples/tab-personal/mvc-csharp/demo-manifest/tab-personal.zip) | +| 2 | Personal tab quick-start | Sample personal tab quick-start app. | Basic | | [View][personal-tab-quickstart#ts] ![toolkit-icon](assets/toolkit-icon.png) | [View][personal-tab-quickstart#js] ![toolkit-icon](assets/toolkit-icon.png) | | +| 3 | Channel and group tabs | Sample app showing custom group and channel Tab with ASP.NET Core. | Basic | [MVC][group-channel-tab#cs#mvc], [Razor][group-channel-tab#cs#razor] | [Yeoman Generator](https://docs.microsoft.com/en-us/microsoftteams/platform/get-started/get-started-yeoman) | | [View](/samples/tab-channel-group/mvc-csharp/demo-manifest/tab-channel-group.zip) | +| 4 | Channel and group tab quick-start | Sample channel and group tab hello world app. | Basic | | [View][group-tab-quickstart#ts] ![toolkit-icon](assets/toolkit-icon.png) | [View][group-tab-quickstart#js] ![toolkit-icon](assets/toolkit-icon.png) | [View](/samples/tab-channel-group-quickstart/js/demo-manifest/tab-channel-group-quickstart.zip) | +| 5 | SPFx Tab | Sample app showing Microsoft Teams tabs using SharePoint Framework. | Basic | | [View][group-channel-tab#ts#spfx] | | | +| 6 | Tab people picker | This is a tab app that shows the feature of the client SDK people picker. | Basic | [View][tab-people-picker#csharp] | | [View][tab-people-picker#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | [View](/samples/tab-people-picker/csharp/demo-manifest/Tab-People-Picker.zip) | +| 7 | Tab channel context | This sample shows the contents of the tab context object in a private and shared channel. | Basic | | [View][tab-channel-context#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | | | +| 8 | tab-ui-templates | This sample app provides tested, high-quality UI templates to help developers understand how to create effective applications for Microsoft Teams, covering common use cases like dashboards and forms. | Basic | | [View][tab-ui-templates#ts] ![toolkit-icon](assets/toolkit-icon.png) | | | +| 9 | Personal tab with SSO quick-start | Sample personal tab with SSO hello world app. | Intermediate | [View][personal-tab-sso-quickstart#csharp] | [View][personal-tab-sso-quickstart#ts] ![toolkit-icon](assets/toolkit-icon.png) | [View][personal-tab-sso-quickstart#js] ![toolkit-icon](assets/toolkit-icon.png) | | +| 10 | Channel and group tab with SSO quick-start | Sample channel and group tab with SSO hello world app. | Intermediate | [View][group-tab-sso-quickstart#csharp] | [View][group-tab-sso-quickstart#ts] ![toolkit-icon](assets/toolkit-icon.png) | [View][group-tab-sso-quickstart#js] ![toolkit-icon](assets/toolkit-icon.png) | | +| 11 | Tab SSO | Microsoft Teams sample app demonstrating Azure AD SSO in a Teams tab using C#. | Intermediate | [View][tab-sso#cs] | [View][tab-sso#ts] ![toolkit-icon](assets/toolkit-icon.png) | | | +| 12 | Deep Link consuming Subentity ID | Microsoft Teams sample app for demonstrating deeplink from Bot chat to Tab consuming Subentity ID. | Intermediate | [View][tab-deeplink#csharp] | | [View][tab-deeplink#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | | +| 13 | Device permissions | Microsoft Teams tab sample app for demonstrating device permissions. | Intermediate | | [View][tab-device-permissions#js] ![toolkit-icon](assets/toolkit-icon.png) | | [View](/samples/tab-device-permissions/nodejs/demo-manifest/tab-device-permissions.zip) | +| 14 | Tab in stage view | This sample app demonstrates the use of Teams tab in stage view using C#, showcasing collaborative features and interactive elements. | Intermediate | [View][tab-stage-view#csharp] | | [View][tab-stage-view#js] ![toolkit-icon](assets/toolkit-icon.png) | [View](/samples/tab-stage-view/csharp/demo-manifest/tab-stage-view.zip) | +| 15 | Product inspection | Demonstrating a feature where the user can scan a product and mark it as approved/rejected. | Intermediate | [View][tab-product-inspection#csharp] | | [View][productinspection#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | [View](/samples/tab-product-inspection/csharp/demo-manifest/Tab-Product-Inspection.zip) | +| 16 | Tab Meeting Transcript Recording | This sample shows meeting transcripts and recordings. | Intermediate | [View][tab-meeting-transcript-recording#csharp] | | [View][tab-meeting-transcript-recording#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | | +| 17 | Tab DeepLink Pass Values | Microsoft Teams sample which displays deeplinks based on the values passed dynamically to the context. | Intermediate | | [View][tab-deeplink-pass-values#ts] | | | +| 18 | Offline Support Tickets | This sample app demonstrates a classic CRUD application that functions offline within Microsoft Teams. When the Android device reconnects to the internet, users can sync their data with blob storage. | Intermediate | | [View][tab-support-offline#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | [View](/samples/tab-support-offline/nodejs/demo-manifest/tab-support-offline.zip) | +| 19 | Tab Meeting Transcript Recording | This sample shows meeting transcripts and recordings. | Intermediate | [View][tab-meeting-transcript-recording#csharp] | | [View][tab-meeting-transcript-recording#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | | +| 20 | Tab DeepLink Pass Values | Microsoft Teams sample which displays deeplinks based on the values passed dynamically to the context. | Intermediate | | [View][tab-deeplink-pass-values#ts] | | | +| 21 | Offline Support Tickets | This sample app demonstrates a classic CRUD application that functions offline within Microsoft Teams. When the Android device reconnects to the internet, users can sync their data with blob storage. | Intermediate | | [View][tab-support-offline#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | [View](/samples/tab-support-offline/nodejs/demo-manifest/tab-support-offline.zip) | +| 22 | Staggered Permission | This sample demos app to request staggered Graph API permissions in Teams tabs. | Advanced | [View][tab-staggered-permission#csharp] | | [View][tab-staggered-permission#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | [View](/samples/tab-staggered-permission/csharp/demo-manifest/tab-staggered-permission.zip) | +| 23 | Tab Multi Hub | Interact with the user's calendar, mail, profile, geolocation from a personal tabs app. | Advanced | | [View][tab-multi-hub#ts] ![toolkit-icon](assets/toolkit-icon.png) | | | +| 24 | Tab External Auth | This sample illustrates how to implement Google auth using external auth providers. | Advanced | [View][tab-external-auth#csharp] | | | | +| 25 | Nested App Authentication | This sample shows nested app authentication (NAA), a new protocol that simplifies single sign-on (SSO) for single-page applications. | Advanced | [View][tab-nested-auth#cs] | [View][tab-nested-auth#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | | | +| 26 | Tab Meeting Recording and transcript with auto recording | This sample shows meeting recording and transcript with auto recording. | Advanced | [View][tab-meeting-auto-recording#csharp] | | | | +| 27 | Tab External Auth | This sample illustrates how to implement Google auth using external auth providers. | Advanced | [View][tab-external-auth#csharp] | | | | +| 28 | Tab Meeting Recording and transcript with auto recording | This sample shows meeting recording and transcript with auto recording. | Advanced | [View][tab-meeting-auto-recording#csharp] | | | | +| 29 | Nested App Authentication | This sample shows nested app authentication (NAA), a new protocol that simplifies single sign-on (SSO) for single-page applications. | Advanced | [View][tab-nested-auth#cs] | [View][tab-nested-auth#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | | | ## [Bots samples](https://docs.microsoft.com/microsoftteams/platform/bots/what-are-bots) (using the v4 SDK) >NOTE: >Visit the [Bot Framework Samples repository][botframework] to view Microsoft Bot Framework v4 SDK task-focused samples for C#, JavaScript, TypeScript, and Python. -| | Sample Name | Description | .NET | JavaScript | Python | Java | App Manifest -|:--:|:-------------------|:---------------------------------------------------------------------------------|:--------|:-------------|:-------------|:-------------|:-------------| -|1| Teams Conversation Bot quick-start | This app showcases bot conversation events and messaging extensions for Microsoft Teams using the Bot Framework v4. | | [View][bot-conversation-quickstart#js] ![toolkit-icon](assets/toolkit-icon.png) | | | -|2| Teams Conversation Bot SSO quick-start | This sample bot demonstrates implementing SSO in Microsoft Teams using Azure AD. | [View][bot-conversation-sso-quickstart#csharp_dotnetcore] | [View][bot-conversation-sso-quickstart#js] ![toolkit-icon](assets/toolkit-icon.png) | | | -|3| Teams Conversation Bot | Messaging and conversation event handling also includes read receipt event functionality in personal scope. Also include AI label, Citations,Feedback buttons,Sensitivity label. | [View][bot-conversation#cs]| [View][bot-conversation#js] ![toolkit-icon](assets/toolkit-icon.png) | [View][bot-conversation#python] | [View][bot-conversation#java] |[View](/samples/bot-conversation/csharp/demo-manifest/bot-conversation.zip) -|4| Message Reactions | This sample app demonstrates how to use message reactions in Microsoft Teams with a bot built on the Bot Framework. | [View][bot-message-reaction#cs] | [View][bot-message-reaction#js] ![toolkit-icon](assets/toolkit-icon.png) | | [View][bot-message-reaction#java]|[View](/samples/bot-message-reaction/csharp/demo-manifest/bot-message-reaction.zip) -|5| Authentication with OAuthPrompt| Authentication and basic messaging in Bot Framework v4. | [View][bot-teams-authentication#cs]| [View][bot-teams-authentication#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | [View][bot-teams-authentication#python] | [View][bot-teams-authentication#java]|[View](/samples/bot-teams-authentication/csharp/demo-manifest/bot-teams-authentication.zip) -|6| Teams File Upload | This bot sample for Teams demonstrates file upload capabilities using Bot Framework v4, enabling users to upload files and view inline images within chats.| [View][bot-file-upload#cs] | [View][bot-file-upload#js] ![toolkit-icon](assets/toolkit-icon.png) | [View][bot-file-upload#python] | [View][bot-file-upload#java]|[View](/samples/bot-file-upload/csharp/demo-manifest/bot-file-upload.zip) -|7| Task Module | Demonstrating how to retrieve a Task Module and values from cards in it, for a Messaging Extension. | [View][bot-task-module#cs] | [View][bot-task-module#js] ![toolkit-icon](assets/toolkit-icon.png) | [View][bot-task-module#python] | [View][bot-task-module#java]|[View](/samples/bot-task-module/csharp/demo-manifest/bot-task-module.zip) -|8| Start new thread in a channel | This app demonstrates how to start a conversation thread in a specific Teams channel using Bot Framework v4. | [View][bot-initiate-thread-in-channel#cs] | [View][bot-initiate-thread-in-channel#js] ![toolkit-icon](assets/toolkit-icon.png) | [View][bot-initiate-thread-in-channel#python] | [View][bot-initiate-thread-in-channel#java] |[View](/samples/bot-initiate-thread-in-channel/csharp/demo-manifest/bot-initiate-thread-in-channel.zip) -|9| Universal bots | This Teams Catering Bot allows users to place food and drink orders seamlessly within Microsoft Teams. It leverages Universal Adaptive Cards for dynamic interactions and supports features like recent orders and order confirmation. | [View](samples/bot-teams-catering/csharp) | | | | -|10| Sequential workflow adaptive cards | Demonstrating on how to implement sequential flow, user specific view and upto date adaptive cards in bot. | [View][sequential#workflow#csharp] | [View][sequential#workflow#js] ![toolkit-icon](assets/toolkit-icon.png) | | |[View](/samples/bot-sequential-flow-adaptive-cards/csharp/demo-manifest/bot-sequential-flow-adaptive-cards.zip) -|11| Channel messages with RSC permissions |This bot can capture all channel messages in Teams using RSC permissions, without the need for @mentions. | [View][messageswithrsc#csharp] |[View][messageswithrsc#js] ![toolkit-icon](assets/toolkit-icon.png) | | |[View](/samples/bot-receive-channel-messages-withRSC/csharp/demo-manifest/Bot-RSC.zip) -|12| Bot with SharePoint file to view in Teams file viewer | This sample demos a bot with capability to upload files to SharePoint site and same files can be viewed in Teams file viewer. |[View][botwithsharepointfileviewer#csharp]|[View][botfileviewer#js] ![toolkit-icon](assets/toolkit-icon.png) -|13| Type ahead search control on Adaptive Cards | This sample shows the feature of type ahead search (static and dynamic) control in Adaptive Cards. |[View][typeaheadsearch#csharp]|[View][typeaheadsearchonadaptivecard#js] ![toolkit-icon](assets/toolkit-icon.png) | | |[View](/samples/bot-type-ahead-search-adaptive-cards/csharp/demo-manifest/Typeahead-search-adaptive-cards.zip) -|14| People picker control in Adaptive Cards | This sample shows the feature of people picker control in Adaptive Cards. |[View][peoplepickeronadaptivecard#csharp]|[View][peoplepickeronadaptivecard#js] ![toolkit-icon](assets/toolkit-icon.png) | | |[View](/samples/bot-people-picker-adaptive-card/csharp/demo-manifest/People-picker-adaptive-card.zip) -|15| Proactive Messaging sample | This sample shows how to save user's conversation reference information to send proactive reminder message using Bots. This uses Teams toolkit for Visual Studio Code to provide scaffolding experience. ||[View][bot-proactive-msg-teamsfx#js] ![toolkit-icon](assets/toolkit-icon.png) -|16| Proactive Tab Conversations | Using a bot to create and store conversations that can be later used inside a sub-entity, tab conversation. This sample includes the details required to proactively message a channel from a bot, set-up and store details for channel tab conversations, and viewing channel conversations from a personal app. |[View][bot-tab-conversations#csharp]| -|17| Suggested Actions Bot | This sample shows the feature where user can send suggested actions using bot. |[View][suggestedactionsbot#csharp]|[View][suggestedactionsbot#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | | |[View](/samples/bot-suggested-actions/csharp/demo-manifest/bot-suggested-actions.zip) -|18| Adaptive Card Actions Bot | This sample demonstrates how to create and send Adaptive Cards with different action types using a Microsoft Teams bot. It includes features like submitting actions, showing cards, toggling visibility, and more. |[View][AdaptiveCardActions#csharp]|[View][AdaptiveCardActions#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | | |[View](/samples/bot-adaptive-card-actions/csharp/demo-manifest/bot-adaptivecard-actions.zip) -|19| SSO for your Adaptive Cards | This sample code demonstrates how to get enable SSO authentication for your Adaptive Cards Universal Actions in bot. |[View][AdaptiveCardSSO#csharp]|[View][BotSSOAdaptiveCard#nodejs] ![toolkit-icon](assets/toolkit-icon.png) -|20| Different formatting on cards | This sample feature shows how to use different formatting on cards using bot. |[View][BotFormattingCards#csharp]|[View][BotFormattingCards#nodejs] ![toolkit-icon](assets/toolkit-icon.png) -|21| Different types of cards using bot | This sample shows the feature where user can interact with different types of cards using bot like Adaptive, hero, list, Office 365 Connector, receipt, sign in, and thumbnail cards and card collections.|[View][TypesCards#csharp] | [View][TypesCards#nodejs] ![toolkit-icon](assets/toolkit-icon.png) -|22| User specific views in Adaptive cards |This sample demonstrates how to create user-specific views in Adaptive Cards within Microsoft Teams, using features like Action.Execute and auto-refresh for dynamic updates. The app enables personalized content, allowing seamless interaction across personal, group, and team contexts. |[View][botadaptivecardsuserspecificviews#csharp]| | | |[View](/samples/bot-adaptivecards-user-specific-views/csharp/demo-manifest/bot-adaptivecards-user-specific-views.zip) -|23| Bot configuration app with type ahead search control.|This sample demonstrates the features of bot configuration and reconfiguration for both teams and group chats, including a type-ahead search (static and dynamic) control on Adaptive Cards.|[View][BotConfigurationApp#csharp]|[View][BotConfigurationApp#nodejs -|23| Bot configuration app with auth |This sample demonstrates the features of bot configuration auth and reconfiguration for both teams and group chats.|[View][BotConfigurationAppAuth#csharp]|[View][BotConfigurationAppAuth#nodejs] -|24| Tag mention bot | This sample app demonstrates the use of tag mention funtionality in teams scope using Bot Framework. |[View][Tagmention#csharp]|[View][Tagmention#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | | | -|25| Commands menu and prompt starters bot | This sample add a command menu with a dropdown list of commands for your bot. Users can select a command from the list, which will insert the command title into the compose box. Then, they can select Send to execute the command. |[View][CommandsMenu#csharp]|[View][CommandsMenu#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | | | -|26| Bot All Cards | Sample which demonstrates sending different types cards supported in teams using bot. |[View][TypesCards#csharp]|[View][TypesCards#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | | |[View](/samples/bot-all-cards/csharp/demo-manifest/bot-all-cards.zip) -|27| Apps in Federated | This sample app allows users to easily view a list of group members. When a new member is added, their details are promptly displayed. ||[View][bot-feed-members#js] ![toolkit-icon](assets/toolkit-icon.png) -|28| Requirement Targeting OneWay Dependency | Microsoft M365 RT sample app in Node.js which specify one-way-dependency relationships between app capabilities (using elementRelationshipSet) and functionality using hostMustSupportFunctionalities. ||[View][RequirementTargetingOneWayDependency#nodejs] ![toolkit-icon](assets/toolkit-icon.png) -|29| Requirement Targeting Mutual Dependency | Microsoft M365 RT sample app in Node.js which specify mutual-dependency relationships between app capabilities using elementRelationshipSet. ||[View][RequirementTargetingMutualDependency#nodejs] ![toolkit-icon](assets/toolkit-icon.png) -|30| Streaming Bot |This sample showcases the conversational streaming token scenario for teams bot in personal scope.|[View][botstreaming#csharp]| | | | +| # | Sample Name | Description | Level | .NET | JavaScript | Python | Java | App Manifest | +|----|----------------------------------------------|----------------------------------------------------------------------------------------------------------------|------------|----------------------------------------------------------------------|------------------------------------------------------------------------|------------------------------------------------------------------------|------------------------------------------------------------------------|--------------------------------------------------------------------| +| 1 | Teams Conversation Bot quick-start | This app showcases bot conversation events and messaging extensions for Microsoft Teams using the Bot Framework v4. | Basic | | [View](bot-conversation-quickstart#js) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 2 | Start new thread in a channel | This app demonstrates how to start a conversation thread in a specific Teams channel using Bot Framework v4. | Basic | [View](bot-initiate-thread-in-channel#cs) | [View](bot-initiate-thread-in-channel#js) ![toolkit-icon](assets/toolkit-icon.png) | [View](bot-initiate-thread-in-channel#python) | [View](bot-initiate-thread-in-channel#java) | [View](/samples/bot-initiate-thread-in-channel/csharp/demo-manifest/bot-initiate-thread-in-channel.zip) | +| 3 | Authentication with OAuthPrompt | Authentication and basic messaging in Bot Framework v4. | Basic | [View](bot-teams-authentication#cs) | [View](bot-teams-authentication#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | [View](bot-teams-authentication#python) | [View](bot-teams-authentication#java) | [View](/samples/bot-teams-authentication/csharp/demo-manifest/bot-teams-authentication.zip) | +| 4 | Teams File Upload | This bot sample for Teams demonstrates file upload capabilities using Bot Framework v4, enabling users to upload files and view inline images within chats. | Intermediate | [View](bot-file-upload#cs) | [View](bot-file-upload#js) ![toolkit-icon](assets/toolkit-icon.png) | [View](bot-file-upload#python) | [View](bot-file-upload#java) | [View](/samples/bot-file-upload/csharp/demo-manifest/bot-file-upload.zip) | +| 5 | Teams Conversation Bot SSO quick-start | This sample bot demonstrates implementing SSO in Microsoft Teams using Azure AD. | Intermediate | [View](bot-conversation-sso-quickstart#csharp_dotnetcore) | [View](bot-conversation-sso-quickstart#js) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 6 | Message Reactions | This sample app demonstrates how to use message reactions in Microsoft Teams with a bot built on the Bot Framework. | Intermediate | [View](bot-message-reaction#cs) | [View](bot-message-reaction#js) ![toolkit-icon](assets/toolkit-icon.png) | | [View](bot-message-reaction#java) | [View](/samples/bot-message-reaction/csharp/demo-manifest/bot-message-reaction.zip) | +| 7 | Task Module | Demonstrating how to retrieve a Task Module and values from cards in it, for a Messaging Extension. | Intermediate | [View](bot-task-module#cs) | [View](bot-task-module#js) ![toolkit-icon](assets/toolkit-icon.png) | [View](bot-task-module#python) | [View](bot-task-module#java) | [View](/samples/bot-task-module/csharp/demo-manifest/bot-task-module.zip) | +| 8 | Proactive Messaging sample | This sample shows how to save user's conversation reference information to send proactive reminder message using Bots. This uses Teams toolkit for Visual Studio Code to provide scaffolding experience. | Intermediate | | [View](bot-proactive-msg-teamsfx#js) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 9 | Channel messages with RSC permissions | This bot can capture all channel messages in Teams using RSC permissions, without the need for @mentions. | Advanced | [View](messageswithrsc#csharp) | [View](messageswithrsc#js) ![toolkit-icon](assets/toolkit-icon.png) | | | [View](/samples/bot-receive-channel-messages-withRSC/csharp/demo-manifest/Bot-RSC.zip) | +| 10 | Proactive Tab Conversations | Using a bot to create and store conversations that can be later used inside a sub-entity, tab conversation. This sample includes the details required to proactively message a channel from a bot, set-up and store details for channel tab conversations, and viewing channel conversations from a personal app. | Intermediate | [View](bot-tab-conversations#csharp) | | | | | +| 11 | Suggested Actions Bot | This sample shows the feature where user can send suggested actions using bot. | Intermediate | [View](suggestedactionsbot#csharp) | [View](suggestedactionsbot#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | | | [View](/samples/bot-suggested-actions/csharp/demo-manifest/bot-suggested-actions.zip) | +| 12 | People picker control in Adaptive Cards | This sample shows the feature of people picker control in Adaptive Cards. | Intermediate | [View](peoplepickeronadaptivecard#csharp) | [View](peoplepickeronadaptivecard#js) ![toolkit-icon](assets/toolkit-icon.png) | | | [View](/samples/bot-people-picker-adaptive-card/csharp/demo-manifest/People-picker-adaptive-card.zip) | +| 13 | Adaptive Card Actions Bot | This sample demonstrates how to create and send Adaptive Cards with different action types using a Microsoft Teams bot. It includes features like submitting actions, showing cards, toggling visibility, and more. | Advanced | [View](AdaptiveCardActions#csharp) | [View](AdaptiveCardActions#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | | | [View](/samples/bot-adaptive-card-actions/csharp/demo-manifest/bot-adaptivecard-actions.zip) | +| 14 | Bot showing news items with translation | This sample shows how to use Adaptive Cards to send news items within Microsoft Teams. | Intermediate | [View](BotNewsCard#csharp) | [View](BotNewsCard#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 15 | Integration with Microsoft Search | Demonstrates how to integrate the Microsoft Search API with your Teams bot to surface relevant information. | Advanced | [View](TeamsBotSearch#csharp) | [View](TeamsBotSearch#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 16 | Calendar bot | The Calendar Bot integrates your Microsoft Teams calendar with a bot to view upcoming events. | Advanced | [View](BotCalendarIntegration#csharp) | [View](BotCalendarIntegration#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 17 | Teams Bot with Video Calling | This sample bot demonstrates the capabilities of integrating video calls in Teams with a bot. | Advanced | [View](TeamsVideoCallBot#csharp) | [View](TeamsVideoCallBot#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 18 | Universal bots | This Teams Catering Bot allows users to place food and drink orders seamlessly within Microsoft Teams. It leverages Universal Adaptive Cards for dynamic interactions and supports features like recent orders and order confirmation. | Advanced | [View](samples/bot-teams-catering/csharp) | | | | | +| 19 | Business process automation with bot | Integrate bots with business process automation within Teams, helping to automate workflows and tasks. | Advanced | [View](BusinessProcessAutomationBot#csharp) | [View](BusinessProcessAutomationBot#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 20 | SSO for your Adaptive Cards | This sample code demonstrates how to enable SSO authentication for your Adaptive Cards Universal Actions in bot. | Advanced | [View](AdaptiveCardSSO#csharp) | [View](BotSSOAdaptiveCard#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 21 | Sequential workflow adaptive cards | Demonstrating on how to implement sequential flow, user specific view and up-to-date adaptive cards in bot. | Advanced | [View](sequential#workflow#csharp) | [View](sequential#workflow#js) ![toolkit-icon](assets/toolkit-icon.png) | | | [View](/samples/bot-sequential-flow-adaptive-cards/csharp/demo-manifest/bot-sequential-flow-adaptive-cards.zip) | +| 22 | Different types of cards using bot | This sample shows the feature where user can interact with bot using various types of cards. | Intermediate | [View](BotDifferentCardTypes#csharp) | [View](BotDifferentCardTypes#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 23 | Running jobs using bot | This sample demonstrates handling long-running jobs via a bot, and sending regular updates to users. | Intermediate | [View](BotLongRunningJobs#csharp) | [View](BotLongRunningJobs#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 24 | Create a bot with a search capability | This example demonstrates how to create a bot that allows users to search for specific information. | Intermediate | [View](BotSearchCapabilites#csharp) | [View](BotSearchCapabilities#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 25 | Teams App Registration Assistant | This tool helps you with registering a Microsoft Teams App and all required assets using simple interaction. | Intermediate | [View](TeamsAppRegistrationAssistant#csharp) | [View](TeamsAppRegistrationAssistant#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 26 | Forms submission Bot | This bot helps you collect data via a customizable form in Teams. It allows users to submit their form and retrieve the results. | Intermediate | [View](FormsBot#csharp) | [View](FormsBot#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 27 | Teams Bot with AI integration | This bot uses AI to automatically respond to user queries and provide intelligent suggestions. | Advanced | [View](TeamsBotWithAI#csharp) | [View](TeamsBotWithAI#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 28 | Teams Bot with Dialogs | This sample demonstrates handling dialogs in Teams Bot Framework, like confirmation and choices. | Intermediate | [View](BotWithDialogs#csharp) | [View](BotWithDialogs#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 29 | Microsoft Graph API integration | This sample shows how to connect to the Microsoft Graph API to pull information into your bot. | Advanced | [View](TeamsGraphAPIBot#csharp) | [View](TeamsGraphAPIBot#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 30 | Adaptive Card example | This sample demonstrates the basic usage of Adaptive Cards in Teams Bot framework to deliver rich content. | Intermediate | [View](bot-adaptive-card#csharp) | [View](bot-adaptive-card#js) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 31 | Secure Communication Bot | This bot ensures encrypted communication using security tools, including Multi-Factor Authentication. | Advanced | [View](securecommunicationbot#csharp) | [View](securecommunicationbot#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | | | | #### Additional samples - -| | Sample Name | Description | .NET | JavaScript | -|:--:|:-------------------|:---------------------------------------------------------------------------------|:--------|:-------------| -|1|Proactive Messaging | Sample to highlight solutions to two challenges with building proactive messaging apps in Microsoft Teams. |[View][bot-proactive-msg#cs] | -|2| Sharepoint List Bot| This sample bot for Microsoft Teams captures user input using adaptive cards and stores the data in a SharePoint list. It includes setup for SharePoint registration, permissions configuration, and deployment in Teams for streamlined data management.| [View][bot-sharepoint-list#cs] | | | -|3|Teams Virtual Assistant| Customized virtual assistant template to support teams capabilities. |[View][app-virtual-assistant#cs]| -|4|User Scope Web App| This sample app demonstrates posting notifications for team/channel changes using Microsoft Graph API in Node.js||[View][user-scope-web-application#js] -|5|Microsoft Teams Tab App Cookie| This sample application demonstrates key web storage features, including managing cookies, SameSite cookies, and partitioned cookies. It also covers local storage and IndexedDB for data persistence in modern web applications.||[View][tab-app-cookie#js] +| No. | Sample Name | Description | Level | .NET | JavaScript | +|-----|:---------------------------------|:----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|:--------------|:--------------------------------------|:-------------------------------------| +| 1 | Microsoft Teams Tab App Cookie | This sample application demonstrates key web storage features, including managing cookies, SameSite cookies, and partitioned cookies. It also covers local storage and IndexedDB for data persistence in modern web applications. | Intermediate | | [View][tab-app-cookie#js] | +| 2 | User Scope Web App | This sample app demonstrates posting notifications for team/channel changes using Microsoft Graph API in Node.js. | Intermediate | | [View][user-scope-web-application#js] | +| 3 | SharePoint List Bot | This sample bot for Microsoft Teams captures user input using adaptive cards and stores the data in a SharePoint list. It includes setup for SharePoint registration, permissions configuration, and deployment in Teams for streamlined data management. | Intermediate | [View][bot-sharepoint-list#cs] | | +| 4 | Proactive Messaging | Sample to highlight solutions to two challenges with building proactive messaging apps in Microsoft Teams. | Advanced | [View][bot-proactive-msg#cs] | | +| 5 | Teams Virtual Assistant | Customized virtual assistant template to support teams capabilities. | Advanced | [View][app-virtual-assistant#cs] | | ## [Messaging Extensions samples](https://docs.microsoft.com/microsoftteams/platform/messaging-extensions/what-are-messaging-extensions) (using the v4 SDK) >NOTE: >Visit the [Bot Framework Samples repository][botframework] to view Microsoft Bot Framework v4 SDK task-focused samples for C#, JavaScript, TypeScript, and Python. -| | Sample Name | Description | .NET | JavaScript | Python| Java | App Manifest| -|:--:|:-------------------|:---------------------------------------------------------------------------------|:--------|:-------------|:-------------|:-------------|:------------- -|1|Messaging extensions - search quick-start | This sample demonstrates a Messaging Extension that accepts search requests and returns results within Microsoft Teams. | | [View][msgext-search-quickstart#js] ![toolkit-icon](assets/toolkit-icon.png) | ||[View](/samples/msgext-search-quickstart/js/demo-manifest/msgext-search-quickstart.zip) -|2|Messaging extensions - search | This sample demonstrates how to create a Messaging Extension in Microsoft Teams that enables users to perform searches and retrieve results seamlessly. | [View][msgext-search#cs] | [View][msgext-search#js] ![toolkit-icon](assets/toolkit-icon.png) | [View][msgext-search#python] | [View][msgext-search#java]|[View](/samples/msgext-search/csharp/demo-manifest/msgext-search.zip) -|3|Messaging extensions - action quick-start | Hello world Messaging Extension that accepts parameters and returns a card. Also, how to receive a forwarded message as a parameter in a Messaging Extension. | | [View][msgext-action-quickstart#js] ![toolkit-icon](assets/toolkit-icon.png) | | |[View](/samples/msgext-action-quickstart/js/demo-manifest/msgext-action-quickstart.zip) -|4|Messaging extensions - action | Messaging Extension that accepts parameters and returns a card. Also, how to receive a forwarded message as a parameter in a Messaging Extension. | [View][msgext-action#cs] | [View][msgext-action#js] ![toolkit-icon](assets/toolkit-icon.png) | [View][msgext-action#python] | [View][msgext-action#java]|[View](/samples/msgext-action/csharp/demo-manifest/msgext-action.zip) -|5|Messaging extensions - auth and config | This sample demonstrates how to create a search Messaging Extension in Microsoft Teams that includes a configuration page and supports user authentication. | [View][msgext-search-auth-config#cs] | | [View][msgext-search-auth-config#python]| |[View](/samples/msgext-search-auth-config/csharp/demo-manifest/msgext-search-auth-config.zip) -|6|Messaging extensions - SSO auth | This sample demonstrates a Messaging Extension for Microsoft Teams that includes a configuration page and supports SSO authentication for enhanced user experience. | [View][msgext-search-sso-config#cs] | [View][msgext-search-sso-config#js] ![toolkit-icon](assets/toolkit-icon.png) | -|7|Messaging extensions - action preview | Demonstrates how to create a Preview and Edit flow for a Messaging Extension. | [View][msgext-action-preview#cs] | [View][msgext-action-preview#js] ![toolkit-icon](assets/toolkit-icon.png) | [View][msgext-action-preview#python] |[View][msgext-action-preview#java]|[View](/samples/msgext-action-preview/csharp/demo-manifest/msgext-action-preview.zip) -|8|Link unfurling |This sample app demonstrates how to implement link unfurling in a Teams messaging extension using the Bot Framework v4. | [View][msgext-link-unfurling#cs] | [View][msgext-link-unfurling#js] ![toolkit-icon](assets/toolkit-icon.png) | [View][msgext-link-unfurling#python] | [View][msgext-link-unfurling#java]|[View](/samples/msgext-link-unfurling/csharp/demo-manifest/msgext-link-unfurling.zip) -|9|Messaging extension - Adaptive Card based loop components | demonstrates a Messaging Extension for Microsoft Teams that utilizes adaptive card-based loop components, enabling link unfurling and dynamic interactions within the compose area.. | [View][msgext-unfurling-ac-loop-components#cs] | [View][msgext-unfurling-ac-loop-components#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | | |[View](/samples/msgext-unfurling-ac-loop-components/csharp/demo-manifest/msgext-unfurling-ac-loop-components.zip) -|10|Messaging Extensions AI - Sentiment Analysis | Messaging Extension with AI capability that performs sentiment analysis (positive/negative/neutral) for messages posted in Microsoft Teams chat |[View][msgext-ai-sentiment-analysis#cs] | [View][msgext-ai-sentiment-analysis#js] ![toolkit-icon](assets/toolkit-icon.png) | | | -|11|Copilot Handoff | This sample implements a Teams message extension that can be used as a plugin for Microsoft Copilot for Microsoft 365. The message extension showcases copilot handoff along with allowings users to query the Northwind Database || [View][msgext-copilot-handoff#js] ![toolkit-icon](assets/toolkit-icon.png) | | | +| # | Sample Name | Description | Level | .NET | JavaScript | Python | Java | App Manifest | +|----|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------------------------------------------------------------|---------------------------------------------------------------------|--------|------|-------------------------------------------------------------| +| 1 | Messaging extensions - action quick-start | Hello world Messaging Extension that accepts parameters and returns a card. Also, how to receive a forwarded message as a parameter in a Messaging Extension. | Basic | | [View](msgext-action-quickstart#js) ![toolkit-icon](assets/toolkit-icon.png) | | | [View](/samples/msgext-action-quickstart/js/demo-manifest/msgext-action-quickstart.zip) | +| 2 | Messaging extensions - search quick-start | This sample demonstrates a Messaging Extension that accepts search requests and returns results within Microsoft Teams. | Basic | | [View](msgext-search-quickstart#js) ![toolkit-icon](assets/toolkit-icon.png) | | | [View](/samples/msgext-search-quickstart/js/demo-manifest/msgext-search-quickstart.zip) | +| 3 | Messaging extensions - action | Messaging Extension that accepts parameters and returns a card. Also, how to receive a forwarded message as a parameter in a Messaging Extension. | Intermediate | [View](msgext-action#cs) | [View](msgext-action#js) ![toolkit-icon](assets/toolkit-icon.png) | [View](msgext-action#python) | [View](msgext-action#java) | [View](/samples/msgext-action/csharp/demo-manifest/msgext-action.zip) | +| 4 | Messaging extensions - search | This sample demonstrates how to create a Messaging Extension in Microsoft Teams that enables users to perform searches and retrieve results seamlessly. | Intermediate | [View](msgext-search#cs) | [View](msgext-search#js) ![toolkit-icon](assets/toolkit-icon.png) | [View](msgext-search#python) | [View](msgext-search#java) | [View](/samples/msgext-search/csharp/demo-manifest/msgext-search.zip) | +| 5 | Messaging extensions - action preview | Demonstrates how to create a Preview and Edit flow for a Messaging Extension. | Intermediate | [View](msgext-action-preview#cs) | [View](msgext-action-preview#js) ![toolkit-icon](assets/toolkit-icon.png) | [View](msgext-action-preview#python) | [View](msgext-action-preview#java) | [View](/samples/msgext-action-preview/csharp/demo-manifest/msgext-action-preview.zip) | +| 6 | Link unfurling | This sample app demonstrates how to implement link unfurling in a Teams messaging extension using the Bot Framework v4. | Intermediate | [View](msgext-link-unfurling#cs) | [View](msgext-link-unfurling#js) ![toolkit-icon](assets/toolkit-icon.png) | [View](msgext-link-unfurling#python) | [View](msgext-link-unfurling#java) | [View](/samples/msgext-link-unfurling/csharp/demo-manifest/msgext-link-unfurling.zip) | +| 7 | Messaging extensions - SSO auth | This sample demonstrates a Messaging Extension for Microsoft Teams that includes a configuration page and supports SSO authentication for enhanced user experience. | Advanced | [View](msgext-search-sso-config#cs) | [View](msgext-search-sso-config#js) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 8 | Messaging extensions - auth and config | This sample demonstrates how to create a search Messaging Extension in Microsoft Teams that includes a configuration page and supports user authentication. | Advanced | [View](msgext-search-auth-config#cs) | | [View](msgext-search-auth-config#python) | | [View](/samples/msgext-search-auth-config/csharp/demo-manifest/msgext-search-auth-config.zip) | +| 9 | Messaging Extensions AI - Sentiment Analysis | Messaging Extension with AI capability that performs sentiment analysis (positive/negative/neutral) for messages posted in Microsoft Teams chat | Advanced | [View](msgext-ai-sentiment-analysis#cs) | [View](msgext-ai-sentiment-analysis#js) ![toolkit-icon](assets/toolkit-icon.png) | | | | +| 10 | Messaging extension - Adaptive Card based loop components | Demonstrates a Messaging Extension for Microsoft Teams that utilizes adaptive card-based loop components, enabling link unfurling and dynamic interactions within the compose area. | Advanced | [View](msgext-unfurling-ac-loop-components#cs) | [View](msgext-unfurling-ac-loop-components#nodejs) ![toolkit-icon](assets/toolkit-icon.png) | | | [View](/samples/msgext-unfurling-ac-loop-components/csharp/demo-manifest/msgext-unfurling-ac-loop-components.zip) | +| 11 | Copilot Handoff | This sample implements a Teams message extension that can be used as a plugin for Microsoft Copilot for Microsoft 365. The message extension showcases copilot handoff along with allowing users to query the Northwind Database | Advanced | | [View](msgext-copilot-handoff#js) ![toolkit-icon](assets/toolkit-icon.png) | | | | #### Additional samples -| | Sample Name | Description | .NET | JavaScript | Python | -|:--:|:-------------------|:---------------------------------------------------------------------------------|:--------|:-------------|:-------------| -|1|Link unfurling demo of Reddit | Messaging Extension with Link Unfurling Samples for Reddit Links |[View][msgext-link-unfurl#cs] | -|2|Link unfurling - setup a meeting | This sample illustrates a common scenario where a user shares a link to a resource with a group of users, and they collaborate to review it in a meeting. |[View][msgext-link-unfurl-meeting#cs] | +| # | Sample Name | Description | Level | .NET | JavaScript | Python | +|----|------------------------------------------|-----------------------------------------------------------------------------|------------|--------------------------------------------------------------------|------------|--------| +| 1 | Link unfurling demo of Reddit | Messaging Extension with Link Unfurling Samples for Reddit Links | Intermediate| [View](msgext-link-unfurl#cs) | | | +| 2 | Link unfurling - setup a meeting | This sample illustrates a common scenario where a user shares a link to a resource with a group of users, and they collaborate to review it in a meeting. | Intermediate| [View](msgext-link-unfurl-meeting#cs) | | | ## [Webhooks and Connectors samples](https://docs.microsoft.com/microsoftteams/platform/webhooks-and-connectors/what-are-webhooks-and-connectors) @@ -162,99 +162,101 @@ The [Teams Toolkit](https://marketplace.visualstudio.com/items?itemName=TeamsDev > > The existing Microsoft 365 (previously called Office 365) connectors across all cloud platforms are nearing deprecation, and the creation of new Microsoft 365 connectors will soon be blocked. For more information on the schedule and how the Workflows app provides a more flexible and secure experience, see [retirement of Microsoft 365 connectors within Microsoft Teams](https://devblogs.microsoft.com/microsoft365dev/retirement-of-office-365-connectors-within-microsoft-teams/). -| | Sample Name | Description | C# | JavaScript | -|:--:|:-------------------|:-------------------------------------------------------------------------------------------------|:--------|:-------------| -|1|Connectors | Sample Office 365 Connector generating notifications to teams channel. |[View][connector#cs] |[View][connector#ts] -|2|Generic connectors sample | Sample code for a generic connector that's easy to customize for any system which supports webhooks. | |[View][connector-generic#ts] -|3|Outgoing Webhooks | Implement Outgoing Webhook for Microsoft Teams for external integrations. |[View][outgoing-webhook#cs]|[View][outgoing-webhook#ts] -|4|Authentication in todo Connector App | This is a sample app which shows connector authentication and sends notification on task creation. ||[View][auth-in-connector#nodejs] -|5|Incoming Webhook | This sample demonstrates a Teams tab to send message cards using Incoming Webhook, showcasing the HttpPOST action for interactive cards. |[View][incoming-webhook#cs] |[View][incoming-webhook#nodejs] +| # | Sample Name | Description | Level | C# | JavaScript | +|----|-----------------------------------|---------------------------------------------------------------------------------------------------------|------------|-----------------------------------|-------------------------------------| +| 1 | Connectors | Sample Office 365 Connector generating notifications to Teams channel. | Intermediate| [View](connector#cs) | [View](connector#ts) | +| 2 | Generic connectors sample | Sample code for a generic connector that's easy to customize for any system which supports webhooks. | Intermediate| | [View](connector-generic#ts) | +| 3 | Incoming Webhook | This sample demonstrates a Teams tab to send message cards using Incoming Webhook, showcasing the HttpPOST action for interactive cards. | Intermediate| [View](incoming-webhook#cs) | [View](incoming-webhook#nodejs) | +| 4 | Outgoing Webhooks | Implement Outgoing Webhook for Microsoft Teams for external integrations. | Intermediate| [View](outgoing-webhook#cs) | [View](outgoing-webhook#ts) | +| 5 | Authentication in Todo Connector App | This is a sample app which shows connector authentication and sends notification on task creation. | Advanced | | [View](auth-in-connector#nodejs) | ## [Graph APIs](https://docs.microsoft.com/graph/teams-concept-overview) -| | Sample Name | Description | C# | JavaScript | App Manifest -|:--:|:-------------------|:-------------------------------------------------------------------------------------------------|:--------|:-------------|:-------------| -|1|Resource Specific Consent (RSC) | This sample illustrates how you can use [Resource Specific Consent (RSC)](https://docs.microsoft.com/en-us/microsoftteams/platform/graph-api/rsc/resource-specific-consent) to call Graph APIs. . |[View][graph#rsc#cs] | [View][graph#rsc#js] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/graph-rsc/csharp/demo-manifest/graph-rsc.zip) -|2|Graph API Channel Life Cycle | This sample illustrates how you can use [Graph API Channel Life Cycle](https://docs.microsoft.com/en-us/graph/api/resources/channel?view=graph-rest-beta) to call Graph APIs. . |[View][graph#lifecycle#cs] | [View][graph#lifecycle#js] ![toolkit-icon](assets/toolkit-icon.png) -|3|Graph API Teams App Installation Life Cycle | This sample illustrates how you can use [Teams App Installation Life Cycle](https://docs.microsoft.com/en-us/graph/api/resources/teamsappinstallation?view=graph-rest-1.0) by calling Microsoft Graph APIs. . |[View][graph#instllationlifecycle#cs] |[View][graph#instllationlifecycle#js] ![toolkit-icon](assets/toolkit-icon.png) | -|4|Graph API Teams App Catalog Life Cycle | This sample demonstrates how to manage the lifecycle of Teams apps in the app catalog using Microsoft Graph APIs through a bot. |[View][graph#appctaloglifecycle#cs] | [View][graph#appcataloglifecycle#js] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/graph-appcatalog-lifecycle/csharp/demo-manifest/graph-appcatalog-lifecycle.zip) -|5|Graph API Chat Life Cycle | This sample illustrates how you can use [Teams App Chat Life Cycle](https://docs.microsoft.com/en-us/graph/api/resources/chat?view=graph-rest-1.0) by calling Microsoft Graph APIs. . |[View][graph#chatlifecyle#cs] |[View][graph#chatlifecycle#js] ![toolkit-icon](assets/toolkit-icon.png) -|6|Activity Feed Notification | Microsoft Teams sample app for Sending Activity feed notification using Graph API in a Teams Tab. | [View][graph-activity-feed#cs] | [View][graph-activity-feed#js] ![toolkit-icon](assets/toolkit-icon.png) | -|7|Proactive installation of App and sending proactive notifications | This sample application demonstrates proactive installation of a Teams app and sending notifications to users using Microsoft Graph APIs. |[View][graph#graphproactiveinstallation#cs] |[View][graph#graphproactiveinstallation#js] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/graph-proactive-installation/csharp/demo-manifest/graph-proactive-installation.zip) -|8|Change Notification | This sample application demonstrates how to send real-time change notifications for user presence in Microsoft Teams. | [View][graph-change-notification#cs] |[View][graph-change-notification#js] ![toolkit-icon](assets/toolkit-icon.png) -|9|Graph Pinned Message |This sample application demonstrates how to pin messages in Microsoft Teams chat using the Graph API and displays all pinned messages in a group chat. | [View][graph-pinned-message#cs]|[View][graph-pinned-message#js] ![toolkit-icon](assets/toolkit-icon.png) | -|10|Graph Bulk Meetings | This sample app demonstrates bulk meeting creation on Teams calendars using an Excel upload. | [View][graph-bulk-meetings#cs]|[View][graph-bulk-meetings#js] ![toolkit-icon](assets/toolkit-icon.png)| -|11|Graph Meeting Notification | This sample application demonstrates how to use an online meeting subscription to send notifications in Microsoft Teams chat when users join, leave, or when meetings start and end. | [View][graph-meeting-notification#cs]|[View][graph-meeting-notification#js] ![toolkit-icon](assets/toolkit-icon.png)| -|12|Change Notifications Team/Channel | This sample application showcases how to post notifications in Microsoft Teams when users create, edit, or delete teams and channels using Microsoft Graph and C#. | [View][change-notifications-team/channel#cs]|[View][change-notifications-team/channel#js] ![toolkit-icon](assets/toolkit-icon.png)| -|13|graph-teams-tag | This sample application demonstrates how to perform CRUD operations on team tags using Microsoft Graph API within a Microsoft Teams tab.| [View][graph-teams-tag#cs]|[View][graph-teams-tag#js] ![toolkit-icon](assets/toolkit-icon.png)| -|14|Graph API Explorer for RSC | Resource-specific consent (RSC) is a Microsoft Teams and Microsoft Graph API integration that enables your app to use API endpoints to manage specific teams within an organization | |[View][graph-rsc-helper#js] ![toolkit-icon](assets/toolkit-icon.png)| +| # | Sample Name | Description | Level | C# | JavaScript | App Manifest | +|----|------------------------------------------------------|---------------------------------------------------------------------------------------------------------|--------------|-----------------------------------|-------------------------------------|--------------------------------------------------------------------| +| 1 | Activity Feed Notification | Microsoft Teams sample app for Sending Activity feed notification using Graph API in a Teams Tab. | Basic | [View](graph-activity-feed#cs) | [View](graph-activity-feed#js) ![toolkit-icon](assets/toolkit-icon.png) | | +| 2 | Graph API Explorer for RSC | Resource-specific consent (RSC) is a Microsoft Teams and Microsoft Graph API integration that enables your app to use API endpoints to manage specific teams within an organization | Basic | | [View](graph-rsc-helper#js) ![toolkit-icon](assets/toolkit-icon.png) | | +| 3 | Graph API Channel Life Cycle | This sample illustrates how you can use [Graph API Channel Life Cycle](https://docs.microsoft.com/en-us/graph/api/resources/channel?view=graph-rest-beta) to call Graph APIs. | Intermediate | [View](graph#lifecycle#cs) | [View](graph#lifecycle#js) ![toolkit-icon](assets/toolkit-icon.png) | | +| 4 | Graph API Teams App Installation Life Cycle | This sample illustrates how you can use [Teams App Installation Life Cycle](https://docs.microsoft.com/en-us/graph/api/resources/teamsappinstallation?view=graph-rest-1.0) by calling Microsoft Graph APIs. | Intermediate | [View](graph#instllationlifecycle#cs) | [View](graph#instllationlifecycle#js) ![toolkit-icon](assets/toolkit-icon.png) | | +| 5 | Graph API Chat Life Cycle | This sample illustrates how you can use [Teams App Chat Life Cycle](https://docs.microsoft.com/en-us/graph/api/resources/chat?view=graph-rest-1.0) by calling Microsoft Graph APIs. | Intermediate | [View](graph#chatlifecyle#cs) | [View](graph#chatlifecycle#js) ![toolkit-icon](assets/toolkit-icon.png) | | +| 6 | Proactive installation of App and sending proactive notifications | This sample application demonstrates proactive installation of a Teams app and sending notifications to users using Microsoft Graph APIs. | Intermediate | [View](graph#graphproactiveinstallation#cs) | [View](graph#graphproactiveinstallation#js) ![toolkit-icon](assets/toolkit-icon.png) | [View](/samples/graph-proactive-installation/csharp/demo-manifest/graph-proactive-installation.zip) | +| 7 | Change Notification | This sample application demonstrates how to send real-time change notifications for user presence in Microsoft Teams. | Intermediate | [View](graph-change-notification#cs) | [View](graph-change-notification#js) ![toolkit-icon](assets/toolkit-icon.png) | | +| 8 | Graph Pinned Message | This sample application demonstrates how to pin messages in Microsoft Teams chat using the Graph API and displays all pinned messages in a group chat. | Intermediate | [View](graph-pinned-message#cs)| [View](graph-pinned-message#js) ![toolkit-icon](assets/toolkit-icon.png) | | +| 9 | Graph Bulk Meetings | This sample app demonstrates bulk meeting creation on Teams calendars using an Excel upload. | Intermediate | [View](graph-bulk-meetings#cs)| [View](graph-bulk-meetings#js) ![toolkit-icon](assets/toolkit-icon.png) | | +| 10 | Graph Meeting Notification | This sample application demonstrates how to use an online meeting subscription to send notifications in Microsoft Teams chat when users join, leave, or when meetings start and end. | Intermediate | [View](graph-meeting-notification#cs)| [View](graph-meeting-notification#js) ![toolkit-icon](assets/toolkit-icon.png) | | +| 11 | Change Notifications Team/Channel | This sample application showcases how to post notifications in Microsoft Teams when users create, edit, or delete teams and channels using Microsoft Graph and C#. | Intermediate | [View](change-notifications-team/channel#cs)| [View](change-notifications-team/channel#js) ![toolkit-icon](assets/toolkit-icon.png) | | +| 12 | graph-teams-tag | This sample application demonstrates how to perform CRUD operations on team tags using Microsoft Graph API within a Microsoft Teams tab. | Intermediate | [View](graph-teams-tag#cs)| [View](graph-teams-tag#js) ![toolkit-icon](assets/toolkit-icon.png) | | +| 13 | Resource Specific Consent (RSC) | This sample illustrates how you can use [Resource Specific Consent (RSC)](https://docs.microsoft.com/en-us/microsoftteams/platform/graph-api/rsc/resource-specific-consent) to call Graph APIs. | Advanced | [View](graph#rsc#cs) | [View](graph#rsc#js) ![toolkit-icon](assets/toolkit-icon.png) | [View](/samples/graph-rsc/csharp/demo-manifest/graph-rsc.zip) | +| 14 | Graph API Teams App Catalog Life Cycle | This sample demonstrates how to manage the lifecycle of Teams apps in the app catalog using Microsoft Graph APIs through a bot. | Advanced | [View](graph#appctaloglifecycle#cs) | [View](graph#appcataloglifecycle#js) ![toolkit-icon](assets/toolkit-icon.png) | [View](/samples/graph-appcatalog-lifecycle/csharp/demo-manifest/graph-appcatalog-lifecycle.zip) | ## [Calls and online meetings bots](https://docs.microsoft.com/microsoftteams/platform/bots/calls-and-meetings/calls-meetings-bots-overview) -| | Sample Name | Description | C# | -|:--:|:------------------|:---------------------------------------------------------------------------------------------------|:--------| -|1|Calling and Meeting bot | This sample demonstrates how a bot can create, join, and transfer calls or meetings within Microsoft Teams. |[View][bot-calling-meeting#csharp] | -|2|Local Media Samples |Local media samples give the developer direct access to the inbound and outbound media streams. |[View](https://github.com/microsoftgraph/microsoft-graph-comms-samples/tree/master/Samples/V1.0Samples/LocalMediaSamples) | -|3|Remote Media Samples | The Incident Bot sample is a Remote Media sample demonstrating a simple incident process workflow started by a Calling Bot.. |[View](https://github.com/microsoftgraph/microsoft-graph-comms-samples/tree/master/Samples/V1.0Samples/RemoteMediaSamples) | +| # | Sample Name | Description | Level | C# | +|----|-----------------------|-------------------------------------------------------------------------------------------------------------------|------------|---------------------------------------| +| 1 | Local Media Samples | Local media samples give the developer direct access to the inbound and outbound media streams. | Intermediate| [View](https://github.com/microsoftgraph/microsoft-graph-comms-samples/tree/master/Samples/V1.0Samples/LocalMediaSamples) | +| 2 | Remote Media Samples | The Incident Bot sample is a Remote Media sample demonstrating a simple incident process workflow started by a Calling Bot. | Intermediate| [View](https://github.com/microsoftgraph/microsoft-graph-comms-samples/tree/master/Samples/V1.0Samples/RemoteMediaSamples) | +| 3 | Calling and Meeting bot| This sample demonstrates how a bot can create, join, and transfer calls or meetings within Microsoft Teams. | Advanced | [View](bot-calling-meeting#csharp) | ## [Meetings samples](https://learn.microsoft.com/microsoftteams/platform/apps-in-teams-meetings/teams-apps-in-meetings) -| | Sample Name | Description | C# | JavaScript |App Manifest| -|:--:|:---------------|:---------------------------------------------------------------------------------|:------|:----------------|:-------| -|1|Meetings Extensibility | The Meeting Token Generator app for Microsoft Teams allows participants to request and manage interaction tokens, ensuring equitable participation during meetings like scrums and Q&A sessions. |[View][meetings-token-app#cs] |[View][meetings-token-app#js] ![toolkit-icon](assets/toolkit-icon.png) -|2|Meetings notification | This sample application demonstrates how to implement in-meeting and targeted notifications within Microsoft Teams meetings using adaptive cards and bot interactions. |[View][meetings-notification#cs] |[View][meetings-notification#js] ![toolkit-icon](assets/toolkit-icon.png) -|3|Meetings SidePanel | This Microsoft Teams sample app demonstrates how to use the Live Share SDK to implement a side panel that allows for real-time data sharing during meetings. |[View][meetings-sidepanel#cs] | [View][meetings-sidepanel#js] ![toolkit-icon](assets/toolkit-icon.png) -|4|Details Tab in Meetings |This sample demonstrates how to create and manage polls during Microsoft Teams meetings, allowing participants to respond and view results through adaptive cards. |[View][meetings-details-tab#cs] |[View][meetings-details-tab#js] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/meetings-details-tab/csharp/demo-manifest/meetings-details-tab.zip) -|5|Meetings Stage View | This sample app demonstrates how to enable and configure applications for Microsoft Teams meetings, allowing users to interact with a shared meeting stage using the Live Share SDK.|[View][meetings-stage-view#cs] |[View][meetings-stage-view#js] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/meetings-stage-view/csharp/demo-manifest/Meeting-stage-view.zip) -|6|Meeting Events | Receive real-time meeting and participant events with this Teams bot sample |[View][meetings-events#cs] | [View][meetings-events#js] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/meetings-events/csharp/demo-manifest/Meetings-Events.zip) -|7|Meeting Recruitment App | Sample app showing meeting app experience for interview scenario.|[View][meeting-recruitment-app#cs] |[View][meeting-recruitment-app#js] ![toolkit-icon](assets/toolkit-icon.png)|[View](/samples/meeting-recruitment-app/csharp/demo-manifest/Meeting-Recruitment-App.zip) -|8|Meeting Transcript App | This sample app retrieves meeting transcripts via the Graph API and showcases them in a task module.|[View][meetings-transcription-app#cs] |[View][meetings-transcription-app#nodejs] ![toolkit-icon](assets/toolkit-icon.png)| -|9|Meeting signing programmatic share to stage|This Microsoft Teams sample app enables users to review and sign documents in real time during meetings, facilitating seamless collaboration.|[View][meetings-share-to-stage-signing#csharp]|| -|10|Meeting Live Caption | This sample application demonstrates how to utilize CART links to send live captions in Microsoft Teams meetings. |[View][meetings-live-caption#cs] |[View][meetings-live-caption#nodejs] ![toolkit-icon](assets/toolkit-icon.png) -|11|Anonymous user support| This sample demonstrates how to support anonymous users in Microsoft Teams meeting apps, showcasing the setup and interaction flow for integrating guest and tenant users seamlessly.|[View][app-anonymous-users#cs] |[View][app-anonymous-users#js] ![toolkit-icon](assets/toolkit-icon.png) | -|12|Live coding interview using Shared meeting stage |This sample application showcases live coding interviews in Microsoft Teams using the Live Share SDK, allowing participants to collaborate in real-time on coding questions.|[View][meetings-live-code-interview#csharp]|[View][meetings-live-code-interview#nodejs] ![toolkit-icon](assets/toolkit-icon.png)| -|13|Meeting-Tabs|This sample shows app stage view, Mute/Unmute Teams meeting audio call and Side panel.|[View][meetingtabs#csharp]|[View][meetingtabs#nodejs] ![toolkit-icon](assets/toolkit-icon.png)| -|14|meetings-attendance-report|This sample application demonstrates how to retrieve meeting attendance reports using the Graph API and send them through a bot in the meeting chat.|[View][meetings-attendance-report#csharp]|[View][meetings-attendance-report#nodejs] ![toolkit-icon](assets/toolkit-icon.png)| -|15|meetings-audio-state|This sample tab application demonstrates how to control meeting audio in Microsoft Teams by muting and unmuting using the Incoming Client Audio API.||[View][meetings-audio-state#nodejs] ![toolkit-icon](assets/toolkit-icon.png)| -|16|meetings-context-app|This sample demonstrates how to retrieve and display meeting context and participant details in Microsoft Teams using bot APIs.|[View][meetings-context-app#csharp]|[View][meetings-context-app#nodejs] ![toolkit-icon](assets/toolkit-icon.png)| + +| # | Sample Name | Description | Level | C# | JavaScript | App Manifest | +|----|---------------------------------|--------------------------------------------------------------------------------------------------------------------|--------------|-----------------------------------------------|----------------------------------------------|----------------------------------------------------------------------------------------------| +| 1 | Meetings Audio State | This sample tab application demonstrates how to control meeting audio in Microsoft Teams by muting and unmuting using the Incoming Client Audio API. | Basic | | [View][meetings-audio-state#nodejs] | ![toolkit-icon](assets/toolkit-icon.png) | +| 2 | Meetings Notification | This sample application demonstrates how to implement in-meeting and targeted notifications within Microsoft Teams meetings using adaptive cards and bot interactions. | Intermediate | [View][meetings-notification#cs] | [View][meetings-notification#js] | | +| 3 | Meetings Context App | This sample demonstrates how to retrieve and display meeting context and participant details in Microsoft Teams using bot APIs. | Intermediate | [View][meetings-context-app#csharp] | [View][meetings-context-app#nodejs] | ![toolkit-icon](assets/toolkit-icon.png) | +| 4 | Meetings Details Tab in Meetings| This sample demonstrates how to create and manage polls during Microsoft Teams meetings, allowing participants to respond and view results through adaptive cards. | Intermediate | [View][meetings-details-tab#cs] | [View][meetings-details-tab#js] | [View](/samples/meetings-details-tab/csharp/demo-manifest/meetings-details-tab.zip) | +| 5 | Meeting Events | Receive real-time meeting and participant events with this Teams bot sample. | Intermediate | [View][meetings-events#cs] | [View][meetings-events#js] | [View](/samples/meetings-events/csharp/demo-manifest/Meetings-Events.zip) | +| 6 | Meeting Recruitment App | Sample app showing meeting app experience for interview scenario. | Intermediate | [View][meeting-recruitment-app#cs] | [View][meeting-recruitment-app#js] | [View](/samples/meeting-recruitment-app/csharp/demo-manifest/Meeting-Recruitment-App.zip) | +| 7 | Meeting-Tabs | This sample shows app stage view, Mute/Unmute Teams meeting audio call, and Side panel. | Intermediate | [View][meetingtabs#csharp] | [View][meetingtabs#nodejs] | ![toolkit-icon](assets/toolkit-icon.png) | +| 8 | Meeting Transcript App | This sample app retrieves meeting transcripts via the Graph API and showcases them in a task module. | Intermediate | [View][meetings-transcription-app#cs] | [View][meetings-transcription-app#nodejs] | | +| 9 | Meetings Attendance Report | This sample application demonstrates how to retrieve meeting attendance reports using the Graph API and send them through a bot in the meeting chat. | Intermediate | [View][meetings-attendance-report#csharp] | [View][meetings-attendance-report#nodejs] | ![toolkit-icon](assets/toolkit-icon.png) | +| 10 | Meetings SidePanel | This Microsoft Teams sample app demonstrates how to use the Live Share SDK to implement a side panel that allows for real-time data sharing during meetings. | Advanced | [View][meetings-sidepanel#cs] | [View][meetings-sidepanel#js] | | +| 11 | Meetings Stage View | This sample app demonstrates how to enable and configure applications for Microsoft Teams meetings, allowing users to interact with a shared meeting stage using the Live Share SDK. | Advanced | [View][meetings-stage-view#cs] | [View][meetings-stage-view#js] | [View](/samples/meetings-stage-view/csharp/demo-manifest/Meeting-stage-view.zip) | +| 12 | Meeting Live Caption | This sample application demonstrates how to utilize CART links to send live captions in Microsoft Teams meetings. | Advanced | [View][meetings-live-caption#cs] | [View][meetings-live-caption#nodejs] | ![toolkit-icon](assets/toolkit-icon.png) | +| 13 | Meetings Extensibility | The Meeting Token Generator app for Microsoft Teams allows participants to request and manage interaction tokens, ensuring equitable participation during meetings like scrums and Q&A sessions. | Advanced | [View][meetings-token-app#cs] | [View][meetings-token-app#js] | | +| 14 | Live Coding Interview using Shared Meeting Stage | This sample application showcases live coding interviews in Microsoft Teams using the Live Share SDK, allowing participants to collaborate in real-time on coding questions. | Advanced | [View][meetings-live-code-interview#csharp] | [View][meetings-live-code-interview#nodejs] | ![toolkit-icon](assets/toolkit-icon.png) | +| 15 | Meeting Signing Programmatic Share to Stage | This Microsoft Teams sample app enables users to review and sign documents in real time during meetings, facilitating seamless collaboration. | Advanced | [View][meetings-share-to-stage-signing#csharp] | | | +| 16 | Anonymous User Support | This sample demonstrates how to support anonymous users in Microsoft Teams meeting apps, showcasing the setup and interaction flow for integrating guest and tenant users seamlessly. | Intermediate | [View][app-anonymous-users#cs] | [View][app-anonymous-users#js] | ![toolkit-icon](assets/toolkit-icon.png) | ## [Actions Preview](https://developer.microsoft.com/en-us/microsoft-365/dev-program) -| | Sample Name | Description | C# | JavaScript |App Manifest| -|:--:|:---------------|:---------------------------------------------------------------------------------|:------|:----------------|:-------| -|1|Actions across Microsoft 365 | This sample demonstrates how to build Teams apps using Actions in the Microsoft 365 app to streamline task management and enhance productivity by minimizing context switching.| |[View][m365-actions-preview#js] ![toolkit-icon](assets/toolkit-icon.png) -## Scenario specific samples +| # | Sample Name | Description | Level | C# | JavaScript | App Manifest | +|----|-----------------------------------|--------------------------------------------------------------------------------------------------------------------|--------------|--------|-----------------------------------------------|---------------------------------------------------| +| 1 | Actions across Microsoft 365 | This sample demonstrates how to build Teams apps using Actions in the Microsoft 365 app to streamline task management and enhance productivity by minimizing context switching. | Intermediate | | [View][m365-actions-preview#js] | ![toolkit-icon](assets/toolkit-icon.png) | -| | Sample Name | Description | C# | JavaScript |App Manifest| -|:--:|:---------------|:---------------------------------------------------------------------------------|:------|:----------------|:-------| -|1|Teams Dialogs (referred as task modules in TeamsJS v1.x) | Sample app showing off the Teams Dialogs(referred as task modules in TeamsJS v1.x), a way to invoke custom code from a bot, a tab, or both! |[View][bot-task-module#cs] |[View][bot-task-module#js] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/bot-task-module/csharp/demo-manifest/bot-task-module.zip) -|2|Authentication| This sample showcases how to implement authentication in Microsoft Teams using both a bot and a tab, supporting Teams SSO with MSAL.js 2.0.| | [View][app-auth#ts] -|3|Complete Samples | Sample covering multiple scenarios - dialogs, ME, and facebook auth. |[View][app-complete#cs] |[View][app-complete#ts] ![toolkit-icon](assets/toolkit-icon.png) -|4|Region Selection App | This Microsoft Teams sample app enables region selection for data centers using both a Bot and a Tab, with interactions through adaptive cards. It demonstrates how to build configurable tabs and conversational bots with Microsoft Teams SDK. |[View][region-selection-app#cs] ||[View](/samples/app-region-selection/csharp/demo-manifest/app-region-selection.zip) -|5|App Localization | This sample demonstrates how to add localization support to Microsoft Teams apps with Bots and Tabs integration. It includes detailed steps for enabling language-specific content and interactions for a seamless multilingual experience. |[View][app-localization#cs] |[View][app-localization#js] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/app-localization/csharp/demo-manifest/app-localization.zip) -|6|App SSO | This C# sample app provides single sign-on (SSO) functionality for Microsoft Teams. It includes authentication support for Teams Tab, Bot, and Messaging Extension with features like user profile retrieval and secure API access using Azure AD. |[View][app-sso#cs] |[View][app-sso#js] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/app-sso/csharp/demo-manifest/App-SSO.zip) -|7| App Installtion using QR code |This sample showcases app installation in Microsoft Teams through QR code scanning, enabling users to generate a QR code that contains the app ID for easy installation. Key features include bot interaction, Teams SSO, adaptive cards, task modules, and device permissions for enhanced user experience. | [View][qrappinstallation#csharp] | [View][qrappinstallation#nodejs] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/app-installation-using-qr-code/csharp/demo-manifest/App-Installation-Using-QR.zip) -|8| Archive groupchat messages | Demonstrating on how a bot can archive groupchat messages and send it to user as a file. | [View][fetchgroupchatmessages#csharp] |[View][fetchgroupchatmessages#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | -|9| App check in location | This sample app allows users to check in with their current location and view a history of previous check-ins via a bot in Microsoft Teams. It showcases features such as bot interaction, adaptive cards, task modules, and the Device Permission API for location access, providing a seamless experience across supported platforms. | [View][appcheckinlocation#csharp] |[View][checkinlocation#nodejs] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/app-checkin-location/csharp/demo-manifest/App-checkin-location.zip) -|10| Message reminder setup through messaging extension | This sample demonstrates a Messaging Extension that allows users to schedule tasks and receive reminder cards in Microsoft Teams.|[View][memessagereminder#csharp]|[View][msgext-message-reminder#nodejs] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/msgext-message-reminder/csharp/demo-manifest/msgext-message-reminder.zip) -|11| Bot daily task reminder | This Teams bot helps users schedule recurring tasks and receive reminders at specified times. It supports adaptive cards and task modules, utilizing the Quartz Scheduler to manage reminders.|[View][botdailytaskreminder#csharp] |[View][bottaskreminder#nodejs] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/bot-daily-task-reminder/csharp/demo-manifest/Bot-Daily-Task-Reminder.zip) -|12| Tab request approval | Demonstrating a feature where user can raise the requests and manager will be notified about the requests and manager will be redirected to approve/reject the request from received notification. |[View][tab-request-approval#csharp]|[View][tab-request-approval#nodejs] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/tab-request-approval/csharp/demo-manifest/Tab-Request-Approval.zip) -|13| Bot request approval | This Teams bot enables users to request task approval from managers within group chats. Managers can quickly approve or reject requests, while other members view request details only.|[View][bot-request-approval#csharp]|[View][bot-request-approval#nodejs] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/bot-request-approval/csharp/demo-manifest/Bot-Request-Approval.zip) -|14| Join the Team using QR code |This sample bot enables users to generate and scan QR codes to join Teams directly. It includes bot, Adaptive Cards, and Graph API support for seamless integration. |[View][qrjointeam#csharp]|[View][qrjointeam#nodejs] ![toolkit-icon](assets/toolkit-icon.png) |[View](/samples/bot-join-team-using-qr-code/csharp/demo-manifest/Bot-Join-Team-By-QR.zip) -|15| Activity feed broadcast |Demonstrating a feature to notify any message to all members of the organisation using activity feed notification .|[View][graph-activity-feed-broadcast#csharp]|[View][graph-activity-feed-broadcast#js] ![toolkit-icon](assets/toolkit-icon.png) | -|16|App complete auth|This sample demos authentication feature in bot,tab and messaging extension.|[View][app-complete-auth#cs]| -|17|Release Management | This is a sample used to send workitem notification using Azure webhook. |[View][release-management#cs] |[View][release-management#nodejs] -|18|Link unfurling for 'Share to teams'|This sample demos the feature of link unfurling for Share to teams.||[View][link-unfurling-stt#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | -|19|App Icon Badging In Microsoft Teams Meetings|This sample app shows the feature of sending app icon badging in Teams' meetings.|[View][meetings-app-icon-badging#csharp]|[View][meetings-app-icon-badging#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | -|20|This sample app demonstrates user search functionality powered by Azure Open AI embeddings and Redis DB, facilitating queries based on files uploaded by an admin using a Teams bot. It supports features like Adaptive Cards, Azure Blob Storage, and Redis integration within Teams.||[View][bot-ai-enterprise-search#nodejs] ![toolkit-icon](assets/toolkit-icon.png) | -|21|Combined Tab and Office Add-in|Demonstrates using add-in to take action on specific Office documents and using tab to aggregate data about all those specific actions.||[View][tab-add-in-combined#ts] ![toolkit-icon](assets/toolkit-icon.png)|[View](/samples/tab-add-in-combined/nodejs/appPackage/build/appPackage.local.zip)||22|Sharepoint tab request approval | This sample app demonstrates the usage of SharePoint Embedded for storage in teams. |[View][sharepoint-tab-request-approval#csharp]|| -|23|App HR talent |This sample app demonstrates integration with a simulated recruiting and talent management system, allowing users to create, manage, and search positions and candidates using Microsoft Teams' bots, tabs, and messaging extensions.|[View][app-HR-talent#csharp]||[View](/samples/app-HR-talent/csharp/src/demo-manifest/TeamsTalentMgmt.zip) +## Scenario specific samples +| # | Sample Name | Description | Level | C# | JavaScript | App Manifest | +|----|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|--------------|--------|-----------------------------------------------|---------------------------------------------------| +| 1 | Teams Dialogs (referred as task modules in TeamsJS v1.x) | Sample app showing off the Teams Dialogs(referred as task modules in TeamsJS v1.x), a way to invoke custom code from a bot, a tab, or both! | Intermediate | [View][bot-task-module#cs] | [View][bot-task-module#js] | [View](/samples/bot-task-module/csharp/demo-manifest/bot-task-module.zip) | +| 2 | Authentication | This sample showcases how to implement authentication in Microsoft Teams using both a bot and a tab, supporting Teams SSO with MSAL.js 2.0. | Intermediate | | [View][app-auth#ts] | | +| 3 | Region Selection App | Enables region selection for data centers using both a Bot and a Tab, with interactions through adaptive cards. | Intermediate | [View][region-selection-app#cs] | | [View](/samples/app-region-selection/csharp/demo-manifest/app-region-selection.zip) | +| 4 | App Localization | Demonstrates adding localization support to Teams apps with Bots and Tabs integration. | Intermediate | [View][app-localization#cs] | [View][app-localization#js] | [View](/samples/app-localization/csharp/demo-manifest/app-localization.zip) | +| 5 | App Installation using QR code | Showcases app installation via QR codes, featuring adaptive cards and task modules. | Intermediate | [View][qrappinstallation#csharp] | [View][qrappinstallation#nodejs] | [View](/samples/app-installation-using-qr-code/csharp/demo-manifest/App-Installation-Using-QR.zip) | +| 6 | Archive Groupchat messages | Demonstrates archiving group chat messages and sending them to users as a file. | Intermediate | [View][fetchgroupchatmessages#csharp] | [View][fetchgroupchatmessages#nodejs] | | +| 7 | App check-in location | Enables location check-ins with bot integration and adaptive cards. | Intermediate | [View][appcheckinlocation#csharp] | [View][checkinlocation#nodejs] | [View](/samples/app-checkin-location/csharp/demo-manifest/App-checkin-location.zip) | +| 8 | Message reminder setup through messaging extension | Allows users to schedule tasks and receive reminders in Teams. | Intermediate | [View][memessagereminder#csharp] | [View][msgext-message-reminder#nodejs] | [View](/samples/msgext-message-reminder/csharp/demo-manifest/msgext-message-reminder.zip) | +| 9 | Bot daily task reminder | Helps users schedule recurring tasks and receive reminders at specified times. | Intermediate | [View][botdailytaskreminder#csharp] | [View][bottaskreminder#nodejs] | [View](/samples/bot-daily-task-reminder/csharp/demo-manifest/Bot-Daily-Task-Reminder.zip) | +| 10 | Tab request approval | Enables users to raise requests for managers to approve or reject, with notifications and task module redirections. | Intermediate | [View][tab-request-approval#csharp] | [View][tab-request-approval#nodejs] | [View](/samples/tab-request-approval/csharp/demo-manifest/Tab-Request-Approval.zip) | +| 11 | Bot request approval | Allows users to request task approval within group chats, with managers approving or rejecting requests. | Intermediate | [View][bot-request-approval#csharp] | [View][bot-request-approval#nodejs] | [View](/samples/bot-request-approval/csharp/demo-manifest/Bot-Request-Approval.zip) | +| 12 | Join the Team using QR code | Enables users to join Teams directly by scanning QR codes, integrating bots, Adaptive Cards, and Graph API. | Intermediate | [View][qrjointeam#csharp] | [View][qrjointeam#nodejs] | [View](/samples/bot-join-team-using-qr-code/csharp/demo-manifest/Bot-Join-Team-By-QR.zip) | +| 13 | Activity feed broadcast | Demonstrates notifying all members of the organization using activity feed notifications. | Intermediate | [View][graph-activity-feed-broadcast#csharp] | [View][graph-activity-feed-broadcast#js] | | +| 14 | App complete auth | Demonstrates authentication features in bot, tab, and messaging extensions. | Intermediate | [View][app-complete-auth#cs] | | | +| 15 | Release Management | Sends work item notifications using Azure webhook. | Intermediate | [View][release-management#cs] | [View][release-management#nodejs] | | +| 16 | Link unfurling for 'Share to Teams' | Demonstrates link unfurling for the "Share to Teams" feature. | Intermediate | | [View][link-unfurling-stt#nodejs] | | +| 17 | App Icon Badging In Microsoft Teams Meetings | Shows how to send app icon badging notifications in Teams meetings. | Intermediate | [View][meetings-app-icon-badging#csharp] | [View][meetings-app-icon-badging#nodejs] | | +| 18 | AI-Powered Enterprise Search Bot | Demonstrates user search functionality powered by Azure Open AI embeddings and Redis DB, supporting file-based queries in Teams bots. | Advanced | | [View][bot-ai-enterprise-search#nodejs] | | +| 19 | Complete Samples | Sample covering multiple scenarios - dialogs, ME, and Facebook auth. | Advanced | [View][app-complete#cs] | [View][app-complete#ts] | | +| 20 | App SSO | Provides SSO functionality for Teams, supporting Tabs, Bots, and Messaging Extensions with secure API access. | Advanced | [View][app-sso#cs] | [View][app-sso#js] | [View](/samples/app-sso/csharp/demo-manifest/App-SSO.zip) | +| 21 | Combined Tab and Office Add-in | Demonstrates using an add-in to act on Office documents and a tab to aggregate data about these actions. | Advanced | | [View][tab-add-in-combined#ts] | [View](/samples/tab-add-in-combined/nodejs/appPackage/build/appPackage.local.zip) | +| 22 | SharePoint Tab Request Approval | Demonstrates using SharePoint Embedded for storage in Teams with tab request approval functionality. | Intermediate | [View][sharepoint-tab-request-approval#csharp]| | | +| 23 | App HR Talent | Integrates with a simulated recruiting and talent management system, supporting bot, tab, and messaging extensions for HR operations. | Advanced | [View][app-HR-talent#csharp] | | [View](/samples/app-HR-talent/csharp/src/demo-manifest/TeamsTalentMgmt.zip) | ## Application templates -| | App Name | Description | Code | -|:--:|:------------------|:---------------------------------------------------------------------------------------------------|:--------| -|1|QBot | QBot is an solution for Microsoft Teams designed to facilitate intelligent question-and-answer interactions among educators, tutors, and students within classroom settings. |[View][msteams-app-qbot] -|2|Resource Hub | Resource Hub is a solution designed for all the help you need to use Teams, all in one place. |[View][msteams-app-resource-hub] +| # | App Name | Description | Level | Code | +|----|----------------|-----------------------------------------------------------------------------------------------------------------|---------------|-------------------------------| +| 2 | Resource Hub | Resource Hub is a solution designed to provide all the help you need to use Teams, all in one place. | Basic | [View][msteams-app-resource-hub] | +| 1 | QBot | QBot is a solution for Microsoft Teams designed to facilitate intelligent Q&A interactions among educators, tutors, and students within classroom settings. | Advanced | [View][msteams-app-qbot] | [app-hello-world#cs]:samples/app-hello-world/csharp