botbuilder-dialogs-adaptive
Version:
Rule system for the Microsoft BotBuilder dialog system.
71 lines (62 loc) • 2.44 kB
text/typescript
/**
* @module botbuilder-dialogs-adaptive
*/
/**
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License.
*/
import { Converter, ConverterFactory, DialogContext } from 'botbuilder-dialogs';
import { InputDialog, InputDialogConfiguration, InputState } from './inputDialog';
import { StringExpression, StringExpressionConverter } from 'adaptive-expressions';
import { StringProperty } from '../properties';
export interface TextInputConfiguration extends InputDialogConfiguration {
outputFormat?: StringProperty;
}
/**
* Declarative text input to gather text data from users.
*/
export class TextInput extends InputDialog implements TextInputConfiguration {
static $kind = 'Microsoft.TextInput';
outputFormat: StringExpression;
/**
* @param property The key of the conditional selector configuration.
* @returns The converter for the selector configuration.
*/
getConverter(property: keyof TextInputConfiguration): Converter | ConverterFactory {
switch (property) {
case 'outputFormat':
return new StringExpressionConverter();
default:
return super.getConverter(property);
}
}
/**
* @protected
* @returns A `string` representing the compute Id.
*/
protected onComputeId(): string {
return `TextInput[${this.prompt && this.prompt.toString()}]`;
}
/**
* @protected
* Called when input has been received.
* @param dc The [DialogContext](xref:botbuilder-dialogs.DialogContext) for the current turn of conversation.
* @returns [InputState](xref:botbuilder-dialogs-adaptive.InputState) which reflects whether input was recognized as valid or not.
*/
protected async onRecognizeInput(dc: DialogContext): Promise<InputState> {
// Treat input as a string
let input: any = dc.state.getValue(InputDialog.VALUE_PROPERTY);
if (typeof input !== 'string') {
return InputState.invalid;
}
if (this.outputFormat) {
const value = this.outputFormat.getValue(dc.state);
if (value && value.trim()) {
input = value;
}
}
// Save formated value and ensure length > 0
dc.state.setValue(InputDialog.VALUE_PROPERTY, input);
return input.length > 0 ? InputState.valid : InputState.unrecognized;
}
}