Secure your code as it's written. Use Snyk Code to scan source code in minutes - no build needed - and fix issues immediately.
module.exports.timeRange = () => {
// Run the recognizer.
const result = Recognizers.recognizeDateTime('Some time between 6pm and 6:30pm.', Recognizers.Culture.English);
// We should find a single result in this example.
result.forEach(result => {
// The resolution includes a single value because there is no ambiguity.
// We are interested in the distinct set of TIMEX expressions.
const distinctTimexExpressions = new Set(
result.resolution.values
.filter(({ timex }) => timex !== undefined)
.map(({ timex }) => timex)
);
// The TIMEX expression captures date ambiguity so there will be a single distinct expression for each result.
console.log(`${ result.text } ( ${ Array.from(distinctTimexExpressions).join(',') } )`);
});
};
module.exports.dateAmbiguity = () => {
// Run the recognizer.
const result = Recognizers.recognizeDateTime('Either Saturday or Sunday would work.', Recognizers.Culture.English);
// We should find two results in this example.
result.forEach(result => {
// The resolution includes two example values: going backwards and forwards from NOW in the calendar.
// Each result includes a TIMEX expression that captures the inherent date but not time ambiguity.
// We are interested in the distinct set of TIMEX expressions.
// There is also either a "value" property on each value or "start" and "end".
// If you use ToString() on a TimeProperty object you will get same "value".
const distinctTimexExpressions = new Set(
result.resolution.values
.filter(({ timex }) => timex !== undefined)
.map(({ timex }) => timex)
);
module.exports.timeAmbiguity = () => {
// Run the recognizer.
const result = Recognizers.recognizeDateTime('We would like to arrive at 4 o\'clock or 5 o\'clock.', Recognizers.Culture.English);
// We should find two results in this example.
result.forEach(result => {
// The resolution includes two example values: one for AM and one for PM.
// Each result includes a TIMEX expression that captures the inherent date but not time ambiguity.
// We are interested in the distinct set of TIMEX expressions.
// There is also either a "value" property on each value or "start" and "end".
// If you use ToString() on a TimeProperty object you will get same "value".
const distinctTimexExpressions = new Set(
result.resolution.values
.filter(({ timex }) => timex !== undefined)
.map(({ timex }) => timex)
);
protected async onRecognize(
context: TurnContext,
state: any,
options: PromptOptions
): Promise> {
const result: PromptRecognizerResult = { succeeded: false };
const activity: Activity = context.activity;
const utterance: string = activity.text;
const locale: string = activity.locale || this.defaultLocale || 'en-us';
const results: any[] = Recognizers.recognizeDateTime(utterance, locale);
if (results.length > 0 && results[0].resolution) {
result.succeeded = true;
result.value = results[0].resolution.values;
}
return result;
}
}
recognize: function recognize(context) {
const request = context.activity || {};
const utterance = request.text || '';
const locale = request.locale || defaultLocale || 'en-us';
const results = Recognizers.recognizeDateTime(utterance, locale);
const values = results.length > 0 && results[0].resolution ? results[0].resolution.values : undefined;
return Promise.resolve(validator ? validator(context, values) : values as any);
}
};
return __awaiter(this, void 0, void 0, function* () {
const result = { succeeded: false };
const activity = context.activity;
const utterance = activity.text;
const locale = activity.locale || this.defaultLocale || 'en-us';
const results = Recognizers.recognizeDateTime(utterance, locale);
if (results.length > 0 && results[0].resolution) {
result.succeeded = true;
result.value = results[0].resolution.values;
}
return result;
});
}
recognize: function recognize(context) {
const request = context.activity || {};
const utterance = request.text || '';
const locale = request.locale || defaultLocale || 'en-us';
const results = Recognizers.recognizeDateTime(utterance, locale);
const values = results.length > 0 && results[0].resolution ? results[0].resolution.values : undefined;
return Promise.resolve(validator ? validator(context, values) : values);
}
};