How to make bots
on Microsoft Bot Framework
data:image/s3,"s3://crabby-images/18c3e/18c3ee3ae2ebf1204f7c90661b48ad2ae1bf861b" alt=""
Shukhratbek Mamadaliev
/ShuhratBek
shuhratbek.26@gmail.com
EPAM, Senior Software Engineer
What is a Chat Bot?
Why Chat Bot?
THE EVOLUTION OF TECHNOLOGY
1980s
PC
- Desktop
1990s
INTERNET
- Search
- "Visits" on website
2000s
MOBILE
- Social
- Other apps to download from stores/markets
FUTURE
CONVERSATIONS
- Natural Language between people and technology
- Conversational canvas
- Bots and agents
Conversational User Interfaces (CUI)
data:image/s3,"s3://crabby-images/1a27a/1a27a82529f4ed4b03c7c926c8e0fbf2a714089e" alt=""
VOICE ASSISTANT
CHATBOTS
CUI - Voice Assistant
CONVERSATIONS
as a platform
DEVELOPERS
BUSINESS
The new canvas
The new opportunity
Where should I use it?
Icon made by Freepik from www.flaticon.com
Icon made by Freepik from www.flaticon.com
Order Pizza (Traditional)
Icon made by Freepik from www.flaticon.com
Order Pizza (Bot)
Handoff to human
An x-ray of a typical bot
data:image/s3,"s3://crabby-images/dc099/dc0991e8c8cc85fe5dcfb98f38d2ae576b51dd09" alt=""
Bot Builder - SDK V4
data:image/s3,"s3://crabby-images/2f48f/2f48f471434b2b469a86ab15f85bb5661f8b0c60" alt=""
data:image/s3,"s3://crabby-images/92892/92892d4b122de5546a68c6eabae446820dd21b46" alt=""
data:image/s3,"s3://crabby-images/c9166/c9166773b0c2385c318490af2886920d18f498f8" alt=""
data:image/s3,"s3://crabby-images/df90b/df90bb03d2011dca8d14999cbbc8197b3513c44c" alt=""
Stable release
Stable release
Preview release
Preview release
Bot Builder CLI tools
(stable release)
Bot Framework Emulator
data:image/s3,"s3://crabby-images/3a845/3a845b09ca3f69f4e24bbf64c89999c24aceab77" alt=""
Bot Framework webchat
data:image/s3,"s3://crabby-images/03b76/03b768b905d06a4c3eef932fe0b601bdb7d8d3f8" alt=""
<!DOCTYPE html>
<html>
<body>
<div id="webchat"></div>
<script src="https://cdn.botframework.com
/botframework-webchat/latest/webchat.js"></script>
<script>
window.WebChat.renderWebChat(
{
directLine: window.WebChat.createDirectLine(
{
secret: 'YOUR_BOT_SECRET_FROM_AZURE_PORTAL'
}
)
}, document.getElementById('webchat'));
</script>
</body>
</html>
botframework-webchat
Bot Framework webchat
React
import DirectLine from 'botframework-directlinejs';
import React from 'react';
import ReactWebChat from 'botframework-webchat';
export default class extends React.Component {
constructor(props) {
super(props);
this.directLine = new DirectLine({ token: 'YOUR_BOT_SECRET' });
}
render() {
return (
<ReactWebChat directLine={ this.directLine } />
element
);
}
}
npm install botframework-webchat
Procedural conversation flow
data:image/s3,"s3://crabby-images/c9bea/c9bea9f879e41618fc13e3070f18c5d410d4c2fd" alt=""
VISION
SPEECH
LANGUAGE
SEARCH
KNOWLEDGE
Language Understanding (LUIS)
www.luis.ai
data:image/s3,"s3://crabby-images/61f9b/61f9bb3db948a58cd73f1986baeb58a59beb8476" alt=""
Language Understanding (LUIS)
data:image/s3,"s3://crabby-images/ec0a3/ec0a34fb16383aa916699e119b78896c927cb782" alt=""
Channels
data:image/s3,"s3://crabby-images/470fb/470fb388594fec73d22f92462be1cb0f384f7e26" alt=""
Bot Development LifeCycle
data:image/s3,"s3://crabby-images/47a14/47a1400cf0302deb0bc0a060fbb15b1ecb7a5dd8" alt=""
Plan
- Don’t send a bot to do a webpages’s job
- Bots are just apps
- Don’t abuse Natural Language Processing
- Sometimes buttons do everything you need
- Its all a matter of User Experience
Build
Locally via
Bot Builder SDK
Azure
data:image/s3,"s3://crabby-images/18c3e/18c3ee3ae2ebf1204f7c90661b48ad2ae1bf861b" alt=""
Test on Azure
data:image/s3,"s3://crabby-images/2bb58/2bb58971e1fc6543f77698d77c43408b2c3af414" alt=""
Test & Debug on Emulator
data:image/s3,"s3://crabby-images/34648/34648e6c4c4df7b19298fc893534d661447bdc07" alt=""
Publish
data:image/s3,"s3://crabby-images/64961/64961e2ad9a29477441bdfcbc65bc6c5e251a881" alt=""
Connect
data:image/s3,"s3://crabby-images/87545/875452f4260a432e628189bbc261ef4a56db3127" alt=""
Evaluate
data:image/s3,"s3://crabby-images/60fa0/60fa0475c913bc161d7b2359a6c274ba7eff940c" alt=""
Rich user controls
Cards
AnimationCard
data:image/s3,"s3://crabby-images/f744d/f744d3e34fe3b97565d3869c3d1a18fa26ddb124" alt=""
AudioCard
data:image/s3,"s3://crabby-images/c16ad/c16ad81aa43ef3bcaaff249db9652b5a81067ab3" alt=""
HeroCard
data:image/s3,"s3://crabby-images/56e1a/56e1a4b5188e1db182d3c8867acb16112d7d3366" alt=""
ThumbnailCard
data:image/s3,"s3://crabby-images/c4219/c421915651d1c225ca1a1a48b26e5d4e3da5f770" alt=""
ReceiptCard
data:image/s3,"s3://crabby-images/d6286/d6286bbffd3baeb7cc8f0d6d4dad99b37bec655d" alt=""
SignInCard
data:image/s3,"s3://crabby-images/8a1ef/8a1ef13ab15ef2c3646f527c7c41621496ef69ed" alt=""
SuggestedAction
data:image/s3,"s3://crabby-images/74801/748010f5861dbe22fa45f6f116efa51882389df5" alt=""
VideoCard
data:image/s3,"s3://crabby-images/2dd74/2dd74bc981a9dc2f77db0462a3fb55c8666e444e" alt=""
CardCarousel
data:image/s3,"s3://crabby-images/01e89/01e892d4f6ddd7f318c05457cc76d01ac4b7d20e" alt=""
AdaptiveCard
data:image/s3,"s3://crabby-images/bf3e3/bf3e30f7a97c8d4e686058152cb3b9b68e400767" alt=""
AdaptiveCard Designer
data:image/s3,"s3://crabby-images/f2e51/f2e51edfce0fa921ae34fc04fbeaa5f29d6685a8" alt=""
DEMO
THANK YOU!
Q&A
How to make bots on Microsoft Bot Framework
By Shuhratbek Mamadaliyev
How to make bots on Microsoft Bot Framework
- 1,476