0.2.0 • Published 6 years ago

botbuilder-composer v0.2.0

Weekly downloads
-
License
MIT
Repository
-
Last release
6 years ago

WARNING! The Library still in active research & development be warned that interfaces will be changed in minor versions before 1.0 release!

Glossary

  • theme - a function or object which will be called to produce/enhance a bot instance. Integrated with event emitter, so able to produce custom events for external subcriber;
  • plugin - a callback function that used to extend a bot instance produced from template. Use to be smaller than theme, but to contain generic reusable logic.

Description

The Library used to compose chatbots from components that leverage Microsoft Bot Framework.

Quick Start

Installation

npm install --save-dev botbuilder-composer

Documentation

Build Sequence

Chatbot build sequence diagram

composer.compose(config)

Returns a Universal bot instance. Config fields:

  • theme function(Universalbot bot, EventEmitter buildEventManager)|ThemeObject
  • plugins function[], array of callback. Every plugin should return a Promise, once all plugin resolved event init will be executed
  • (optional) bot UniversalBot - if empty, compose will create instance of UniversalBot and will pass it to theme and callbacks.

ThemeObject

  • beforeInit: function( bot, buildEventManager)
  • build: function( bot, buildEventManager). Value returned by function will be resolved as a promise.

Standard Events

  • init - called when theme and all plugin callbacks executed
  • complete - called after

Library Templates

Intent With Menu

This template provide a basic template for a bot. Template features:

  • first run dialog support
  • greeting dialog support
  • extendable intents dialog

API

  • constructor -
  • addMenuItem(Object config) -
  • getMenu() -
  • sendMessageWithMenuActions -
  • addIntent(intentName, dialogName) -
  • addRecognizer(recognizer) -
  • setFirstRunDialogId(string dialogId) -
  • setDefaultDialogId(string dialogId) -
  • setGreetingDialogId(string dialogId) -

Example

Changelog

  • 0.1.0 - initial release