UNPKG

type2docfx

Version:

A tool to convert json format output from TypeDoc to universal reference model for DocFx to consume.

147 lines (134 loc) 5.97 kB
/** * @module botbuilder-dialogs */ /** * Copyright (c) Microsoft Corporation. All rights reserved. * Licensed under the MIT License. */ import { Activity } from 'botbuilder'; import { Dialog } from '../dialog'; import { DialogSet } from '../dialogSet'; import { PromptOptions, PromptValidator } from './prompt'; import { ListStyle, formatChoicePrompt } from './choicePrompt'; import { ChoiceStylerOptions, Choice } from 'botbuilder-choices'; import * as Recognizers from '@microsoft/recognizers-text-options'; const booleanModel = Recognizers.OptionsRecognizer.instance.getBooleanModel('en-us'); /** Map of `ConfirmPrompt` choices for each locale the bot supports. */ export interface ConfirmChoices { [locale:string]: (string|Choice)[]; } /** Additional options that can be used to configure a `ChoicePrompt`. */ export interface ConfirmPromptOptions extends PromptOptions { /** Preferred style of the yes/no choices sent to the user. The default value is `ListStyle.auto`. */ style?: ListStyle; } /** * Prompts a user to confirm something with a yes/no response. By default the prompt will return * to the calling dialog a `boolean` representing the users selection. * * **Example usage:** * * ```JavaScript * const { DialogSet, ConfirmPrompt } = require('botbuilder-dialogs'); * * const dialogs = new DialogSet(); * * dialogs.add('confirmPrompt', new ConfirmPrompt()); * * dialogs.add('confirmDemo', [ * function (context) { * return dialogs.prompt(context, 'confirmPrompt', `confirm: answer "yes" or "no"`); * }, * function (context, value) { * context.reply(`Recognized value: ${value}`); * return dialogs.end(context); * } * ]); * ``` */ export class ConfirmPrompt implements Dialog { /** * Allows for the localization of the confirm prompts yes/no choices to other locales besides * english. The key of each entry is the languages locale code and should be lower cased. A * default fallback set of choices can be specified using a key of '*'. * * **Example usage:** * * ```JavaScript * // Configure yes/no choices for english and spanish (default) * ConfirmPrompt.choices['*'] = ['sí', 'no']; * ConfirmPrompt.choices['es'] = ['sí', 'no']; * ConfirmPrompt.choices['en-us'] = ['yes', 'no']; * ``` */ static choices: ConfirmChoices = { '*': ['yes', 'no'] }; /** Additional options passed to the `ChoiceStyler` and used to tweak the style of yes/no choices rendered to the user. */ public readonly stylerOptions: ChoiceStylerOptions; /** * Creates a new instance of the prompt. * * **Example usage:** * * ```JavaScript * dialogs.add('confirmPrompt', new ConfirmPrompt((context, value) => { * if (value === undefined) { * context.reply(`Please answer with "yes" or "no".`); * return Prompts.resolve(); * } else { * return dialogs.end(context, values); * } * })); * ``` * @param validator (Optional) validator that will be called each time the user responds to the prompt. */ constructor(private validator?: PromptValidator<boolean|undefined>) { this.stylerOptions = { includeNumbers: false }; } public begin(context: BotContext, dialogs: DialogSet, options: ConfirmPromptOptions): Promise<void> { // Persist options const instance = dialogs.getInstance<ConfirmPromptOptions>(context); instance.state = options || {}; // Send initial prompt if (instance.state.prompt) { return this.sendChoicePrompt(context, dialogs, instance.state.prompt, instance.state.speak); } else { return Promise.resolve(); } } public continue(context: BotContext, dialogs: DialogSet): Promise<void> { // Recognize value const options = dialogs.getInstance<ConfirmPromptOptions>(context).state; const utterance = context.request && context.request.text ? context.request.text : ''; const results = booleanModel.parse(utterance); const value = results.length > 0 && results[0].resolution ? results[0].resolution.value : undefined; if (this.validator) { // Call validator for further processing return Promise.resolve(this.validator(context, value, dialogs)); } else if (typeof value === 'boolean') { // Return recognized value return dialogs.end(context, value); } else if (options.retryPrompt) { // Send retry prompt to user return this.sendChoicePrompt(context, dialogs, options.retryPrompt, options.retrySpeak); } else if (options.prompt) { // Send original prompt to user return this.sendChoicePrompt(context, dialogs, options.prompt, options.speak); } else { return Promise.resolve(); } } protected sendChoicePrompt(context: BotContext, dialogs: DialogSet, prompt: string|Partial<Activity>, speak?: string): Promise<void> { if (typeof prompt === 'string') { // Get locale specific choices let locale = context.request && context.request.locale ? context.request.locale.toLowerCase() : '*'; if (!ConfirmPrompt.choices.hasOwnProperty(locale)) { locale = '*' } const choices = ConfirmPrompt.choices[locale]; // Reply with formatted prompt const style = dialogs.getInstance<ConfirmPromptOptions>(context).state.style; context.reply(formatChoicePrompt(context, choices, prompt, speak, this.stylerOptions, style)) } else { context.reply(prompt); } return Promise.resolve(); } }