Skip to content

Enhanced SharePoint Framework (SPFx) Microsoft Bot Framework Web Chat

Notifications You must be signed in to change notification settings

juanjoarranz/spfx-react-bot-qna

Repository files navigation

Enhanced SPFx Microsoft Bot Framework Web Chat

Summary

A web part that acts as a web chat component for bot's built on the Microsoft Bot Framework using the Direct Line API. When sending messages the web part uses the username of the currently logged in user. The web part has settings for color for branding purposes.

bot framework client web part

This web part is a very enhanced version of the original one found in the PnP SPFx Sample: Microsoft Bot Framework Web Chat.

You can see the original web part sample in practice from PnP SPFx Special Interest Group recording where sample was demonstrated.

Used SharePoint Framework Version

drop

Applies to

Prerequisites

You need to have a bot created and registered using the Microsoft Bot Framework and registered to use the Direct Line Channel, which will give you the secret needed when adding this web part to the page. For more information on creating a bot and registering the channel you can see the official web site at dev.botframework.com, as well as various tutorials over at www.garypretty.co.uk/category/microsoft-bot-framework/

See more details on how to create a bot from following locations.

Solution

Solution Author(s)
spfx-react-bot-framework Juanjo Arranz

Version history

Version Date Comments
1.0 April 18th, 2019 Initial release

Disclaimer

THIS CODE IS PROVIDED AS IS WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING ANY IMPLIED WARRANTIES OF FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABILITY, OR NON-INFRINGEMENT.


Minimal Path to Awesome

  • Clone this repository

  • in the command line run:

    • npm install
    • tsd install
    • gulp serve
  • Register your bot in the Microsoft Bot Framework Portal, configure the Direct Line channel on the bot and obtain your Direct Line secret.

Features

This Web Part illustrates the following concepts on top of the SharePoint Framework:

  • Connecting and communicating with a bot built on the Microsoft Bot Framework using the Direct Line Channel
  • Validating Property Pane Settings
  • Office UI Fabric
  • React

When adding the web part to a page you need to obtain your Bot Direct Line Channel secret via the Bot Framework Portal. You then add this secret via the Property Pane of the web part. If there is an error initializing the Direct Line Client with the bot then they will be shown in the console within the browser.

You can add Direct Line channel to bot from the bot details page under the "Add another channel" section

bot framework client web part

After this, you can click Edit for the just added Channel to get the needed secret for the client side web part.

bot framework client web part

Additional settings can be set to style the web part, including;

  • Display title of the web part
  • Web part header background color
  • Placeholder text
  • Foreground / background colors for messages, both from the user and from the bot

Currently this web part only supports plain text conversations with a bot. Other message types, such as Rich Cards and Attachments are not supported, but are on the roadmap for a future update.